SND~E Desk 


Xylogics 


Model 752 
_ User's Manual 


iy 
Lhd 
if tg 


- 
‘ ¢ 
_ a Oh _ 
2a 8 GF - 


YOUR PARTNER FOR PERFORMANCE. 


166-752-001 


Revision A Copyright 1987 
June 15, 1987 Xylogics, Inc. 


The information in this manual is subject to change without 

notice, and should not be construed as a commitment by Xylogics. 

Xylogics assumes no responsibility for any errors that may appear 
in this document. 


— oXylogics 


Model 752 
User's Manual 


YOUR PARTNER FOR PERFORMANCE. 


166-752-001 


Revision A Copyright 1987 
June 15, 1987 Xylogics, Inc. 


XYLOGICS 752 Disk Controller User's Manual 


752 REVISION LEVEL HISTORY 


| REVISION | DESCRIPTION | 


| A (6/15/87) | Initial release. | 


Rev. A. June 15, 1987 


XYLOGICS 752 Disk Controller User's Manual 


TABLE OF CONTENTS 


PAGE 


LIST OF ILLUSTRATIONS @eeeeovoeaeeveaee epee oes evoeaeeeoeeesceeoesvpeveeeeeeeaesoeoeaoaoee ov eoee@ 0 8 @ Xi 


SECTION 1: SPECIFICATIONS 


1.0 
1.1 


1.2 
1.3 
1.4 
1.5 
1.6 
1.7 
1.8 
1.9 


1.10 


GENERAL @eeeoeeeeceeceaes ea eoeaeaovoeaeaeeoeoev eee eoeeaea even eos eaeWaeoaoeeaeeaneeaoeeee ee ee 


USING THIS MANUAL @eeeeeoevoeaeeuaweaevoeee@aeea@eoeaeaoeoeveaeoeweaes eae oe eases eee eee ee ee 8 @ 


Leaked Abbreviations eeeeeoeeaeveveaeaev eeoeveeoeeveeaoeveeeeveaevneoeaoecoeae evn eaee@enee ee @ 


Db HE F 


DESIGN RELIABILITY ccccccccvcccccccccccvcccccccsccccresceecceees 
PHYSICAL: se:0:5 605s W600 Wn 66 we Ge Sides wSwS 6 00's 0.4 Wie 0.6.5 Owes We ewes sie So 
ENVIRONMENTAL scccccccccccccccccccccsccsccscccccccccccsssseseees 3 
ELECTRICAL: +6000 ¢.e/e6.0:6:6' 66's WW e's Sra eee SOE CO CONOR ese ee eee So 
SYSTEM RELATED SPECIFICATIONS .ccccccccvccccccccccccccceeccseces 3 
DISK DRIVE RELATED SPECIFICATIONS .cccccccccccvccccccccccccccecs 

VMEbus RELATED SPECIFICATIONS .ccccccccccccccccccccccccccccccces 


5 
6 
SOFTWARE RELATED SPECIFICATIONS .ccccccccccccccccccccccccccccccs | 
1.9.1 Software Interface ..ccccccccccccccccccccccervcsesccsccce | 

8 


PROGRAMMABLE FEATURES eeaeeveaoevoeeeoeaesceaeeeaeeeoeoeaeoeaeeaoeeeaeeve@soeoeaeaen ee 0 @ 


SECTION 2: INSTALLING AND TESTING THE 752 


2.0 


21 


2.2 


GENERAL eeoeeevoeauea oe eoeaoeneeaoeaeseeeaoeaneoea eo ea@ eee eee oeo eee eeeoeoaeaeeea@a@eoe eee eaee eee 0 


UNPACKING AND INSPECTION mlanidoueteaistuatsiae.c cetealt anes cine eee cmieaies 


2.1.1 Inspect the Shipping Carton ..cccccccccccccccccccccccces 
Zels 
Zee 
2.1 


Contents eesceeeeveeoe ees eoeooeoeeoevoeeaeeveeoseoeoe@aeeveeae eee eeaeac ewe ovoeaeoeee eee @ 


2 
e3 Handling Precautions eeoeaeeoeoeaedce@a@eoaoovaeeaeoeeoe@aovpeen@weoee@soeaoed eee 0 @ 
4 Inspect the 752 @eeeaeeoeaeveeovoeoeaoev ee eoeoeoeveeeaeoseeeoeaseeoaecuevoeuaueaoeneeee ee @ 


WO WO WO © Ne) Co) 


CONFIGURING THE 752 @eeseeoeoeneuoacuaeoecoeaevecoeoeevneveaneacuaeeeevoeeoeaeoev eee eee e ee 6 10 


zeldel Base Address Selection ecoeoeeoecea eoceoeeeoeveaeevoeaaevoeueaeve@eeaoe@a eee 8 @ ll 
2.2.2 Bus Request and BuS Grant Lin€S ..cccccccccccccccccccee 12 
Lites Parallel Arbitration ecoee5ua voceeeecvoeeeoeaeveeeeoeaeeuaeneoaoea ves eee@ 12 


-j- 


Rev. A. June 15, 1987 


XYLOGICS 752 Disk Controller User's Manual 


TABLE OF CONTENTS 
PAGE 
2.3 PROMS AND PALS Pere eee rere ere eee eee eee ree eee eee eee rere 13 
2.4 SELF TEST DISABLE eeeeeeee9e1eegeeceeeaesee44see*eeeeeseee4aeegeese@eeaeeanseeeaesgeesgesns ee @ 13 
2.5 PROMS AND PALS e@eeoeoeeeoee0ec40aue94agag@*esesee@edse¢eeeseeeaeeVesegcenweCeeae@eeeaeesoag@eedseseeoeaeeneee @ 13 
2 e 6 LIGHT EMITTING DIODES eeeeooeoeeaese@eeeoeeeaeeeseew@woeanosgeeesaseeaeeogeeesese0eed@eeseVeneen 8 Oe @ 13 
2.7 BOARD LABELS / REVISION CONTROL @e@eeeeeedeseeseesnegeeoeeoeeeeeW@a@aeaeaegeeeeeeee 13 
2.8 PREPARING THE COMPUTER SYSTEM FOR INSTALLATION ....cccccceeccee 14 
2 e 8 e 1 Backplane Jumpe rs eee@eoeoeeoeeoaeoe@eeeeeeeeeeon@eeseeaeeeaeedceeeeee 8 @ 14 
28.2 Cara Cage Slot e@eeoeoeoeaedesge@eeeeeeeeneeaeeceeeaeneg@aqdndegce@eeonosnedgeeeed ee @ 14 
2 @ 8 @ 3 Power Considerations eee@e@eee9eqe*eedaedseeeeeeeee~a4@awegwneaeoaeeaesdseoeeodeees @ 14 
2.9 PREPARING THE DISK DRIVE FOR INSTALLATION ....eccccccccecccecee 15 
2 9 1 Drive Unit Select eee@eeeee?gee7sese¢eeseeese@eaeV@eeeaese@eetc@aescgceaqgcee@e~dee3@e ees @ 15 
2.9.2 Number of Sectors Per Track ..cccccccccccccccccccccevee LD 
2 t ) 9 6 3 Sector and Index Pulses eeeoeoeeee<ae4ageececec@eeoaee4e@oee4aeae@eCesg@e~e@e3e@oe3egegeeeee@e 15 
2 9 4 Tags 4 and 5 e@eeeoeeeoeeeeaeseeg@oaeeaeoeaeoecgc@e~edsdeoszoeaeaeae@edesceeeeadcgc@~qdcsnkeedcoase@eaqdoeee eee 8 @ 15 
2.9.5 Extended Cylinder AddreSSing ...cccccccccccccsccsccscccce LO 
2.10 INITIAL TESTS ee@e@eeseeoasoeeaees14eeaeeeeeds?deeeae<@aegqege@eddeteoeeUeuesoqg_ee@eeeaeeeeGegeeaeee@eeseeeeees@ 16 


2.10.1 Power-up and Self Test eeeeevoeeeoeveaeceeaeveeose eoeeeaecenevned ee eee ee @ 16 
2.10.2 Drive Ready @eeeaeeestpoeoeoveeeosnenvneaeevpeeeesveoeaeovoeaeeoeonvneeoeoee ee eee @ 16 


2el1l DIAGNOSTICS eeoaeeoeacoeeseeevpea~e oesvpeovaeaeeovuoeaoeeseeaesesoeeaee ee eeeaeeeeaea eee eee ee 16 


SECTION 3: THE 752 REGISTERS 
3.0 GENERAL @eeeeeseovoeoevoeevoeeeeeveaoeeeoevoeeaeseeeveeaeveaeeoseeoevoeeeoeeeoeeeaeeaeaeeeoee eee 8 @ 17 
3.1 IOPB ADDRESS REGISTERS eeeeoevoeneoeceoeoaescoeoeceeaoeeeaeoeeeeeaoeoeaeeeeea4uaneoee ee ee @ 17 


3.2 IOPB ADDRESS MODIFIER eeoeeaee eo eooaoeeaeeaoe eevee evoeoeeaeaoeeoeeeveeaoeeaeeaevn eee eee @ 17 


-~ii- 


Rev. A. June 15, 1987 


XYLOGICS 752 Disk Controller User's Manual 


3.3 


3.4 


TABLE OF CONTENTS 
PAGE 
CONTROL AND STATUS REGISTER eeeeoeeecvevaeoecoeoeeaoeoeeaseeoeoeea@eseoceaoeeeveaeneoe eee @ 18 


Sedel. *“CONEFOL Register: (WELCC). b.ccivicsends seeseseeesseseewes: LS 
3.322 Status Register (Read) eeeeoevseaeeoaeae@weaeceeaeeeoeeoeeeeeeeeeee 8 @ 20 


FATAL ERROR REGISTER eeeveeeaevoeaeoeveevoeveeveoeaeeoeoeeeoevoeeeoeoeeeoeeaeneee ee eee @ 22 


SECTION 4: IOPB DESCRIPTION 


4.0 
4.1 


4.2 


GENERAL eeeoe@eeoeceac ono eoeo eee eeaeeveeaeeeeeoeeeaeaeoeea ev eoeeveevaeaeeoeaoeeeceo@aeeaee oe eee @ 23 


STANDARD IOPB @eeeoeoaoescoeoceaeeoeoeeeeveoaeeaeaeveeeeeaoeeo eo eeoeoeee eee eeeaeoeoe eo ee @ 23 


IOPB Byte 0 (Command) .ccccccccccvcccccvcvecscscccccsece 24 
IOPB Byte 1 (Status Byte 1) ccccccccccccccccscccceseses 20 
IOPB Byte 2 (StatusS Byte 2) ccccccccccccccscccccsccecsse LO 
IOPB Byte 3 (Status Byte 3) cccccccccccsecccscccccscseese 20 
IOPB Byte 4 (Subf£unction) eccccccccccccccsccccccescscces 20 
TOPS: Byte 5: (ULE) vos ccebeb adiewtiesee snes ee ccuwvecseees: 20 
IOPB Byte 6 (Interrupt Level) ...cccccccccsccccccccscee 29 
IOPB Byte 7 (Interrupt VeECtOr) ...ccccccccccccscccccvce 29 
IOPB Bytes 8 and 9 (COUNT) .ccccccccccsccccccccccccccce 29 
IOPB Bytes A and B (Cylinder) .orccccccccccccccccscccces 29. 
IOPB Byte C (Head) ccccccccccccvcccscccccccscccscccesere 30 
JOPB Byte: D: (SECEOL) 6 i.i60séces ew de wees se cweec cee sedeeee 30 
IOPB Byte E (Data or Link Address Modifier) .cccocccese 30 
IOPB Byte F (Next IOPB Address Modifier) ...ccccscccesee 30 
IOPB Bytes 10 Through 13 (DMA Data Address) .......--.. 31 
IOPB Bytes 14 Through 17 (Next IOPB AddreSs) ..c..eeceee 31 
IOPB Bytes 18 and 19 (IOPB Checksum) .....cccccccecceee SL 
IOPB Bytes 1A and 1B (ECC Pattern Word) .ccccccccscccee 31 
IOPB Bytes 1C and 1D (ECC Offset Word) .cccccccccccccee 31 


e e 
e 
OV UI & WN FF 


WONDA UP WNHEHO 


hh DL AALAA AAA LA HLL HAD B® 
@ 

ee oe ed Oe ee ee 
6 

Be HEHE HOOD U PWD 


CONTROLLER PARAME' TERS IOPB eecoevoeeceaea@nvneaeeaeoeosvoeeeeeeoeeaovoea@svneaecea eo eee @ 32 


IOPB Byte 8 (Controller Parameters A) wcccccccccccccveee 32 
IOPB Byte 9 (Controller ParameterS B) ccccceccccsccceee 34 
IOPB Byte A (Controller ParameterS C) cccccccccccccceee 30 
IOPB Byte B (Controller ParameterS D) .ccccsccccccsceee 30 
IOPB Byte C (EPROM Release Level) ccccccccccccecccccese 30 
IOPB Byte E (Controller Type) corccccccccccccccecccevees 30 
-IOPB Bytes 10 and 11 (EPROM Part Number) .....cccccceee 36 
IOPB Byte 12 (EPROM Revision Level) .ccccccccccccccccee 3/ 


e 
NON NN NH NN DP 
e@ 
ONDU WN EE 


ff. PP LP Pf Pp 
e i) @ 
@ e 


= 113 = 


Rev. A. June 15, 1987 


XYLOGICS 752 Disk Controller User's Manual 


TABLE OF CONTENTS 
PAGE 
4.3 DRIVE PARAMETERS IOPB sae eae acts asciearssseees essed dese teste ik ira ses ssreesiast 37 


IOPB Byte 6 (Drive ParaMetersS) cccccccccccccccccccccces 3G 
IOPB Byte 8 (Max Sector /Last Head) @eeeeaeeaeeo e@oeeeaodveeaoe e@ee @ 39 
IOPB Byte 9 (Head Offset) @e@eeeaeeooeaeaeooeoee oo eoenveeoeeneeeeee28080 0 39 
IOPB Bytes A and B (Max Cylinder) ..cccccccccccccccccese 39 
IOPB Byte C (Max Head) ®eeeaecovoevoeaoeoeneoeen eee eeeeeeoeees eee eee @ 39 
IOPB Byte D (Max Sector ) eeoe@eondoeevoeoeoeeoeaeeoeoevneoenee2e0e2eee0 0808 @ 39 
IOPB Byte E (Sectors Per Track) cccccccccccccccccccccee 39 


- & hb Lb Lh 
e 

WWW WWW W 
e 

“OV Om WD 


4,4 FORMAT PARAME TERS IOPB @eeeaeeoeoecaoenoe 2oeeoeocovoeaeeeeaneoeeoeeaeevneeoeoseeeeaeeoee eee eee 40 


IOPB Byte 6 (Interleave) wccccccccccccccccccccccscscccce 40 
IOPB Byte & (Field 1) ccsvccccccccccccccevccvcccccccsess 41 
TOPB Byte 9 (Field 2) wseccccscccvcccvecccevccccssccese 4) 
IOPB Byte A (Field 3) wcccccccscccccssveccccccccvcccees 42 
IOPB Byte B (FielG 4) wsccccccsccsccccccvecsveseseccces 42 
IOPB Bytes C and D (Bytes Per Sector High/LOwW) ..c.ceccs 42 
LOPS Byte 10 (PieGld 6) sciwsewsweesSeccsewsveneeisveseee “42 
IOPB Byte 11 (Field 7) .cccccccccccvccccccvccccccsecces 42 


e 
PP Ph hh Pb fh > 
e 


e 
e ee 
ONAN US WD EE 


PF PP LP hb hb 
eo. e 
ee 


SECTION 5: COMMANDS 
5.0 GENERAL eeeeenoeeoeeovn@easeeeooeeeeveeeenaeneeoessvseaoeeeeeae eee eaoeaeenaseeeneea eee e ee @ 43 


5.0.1 Setting Up The Command eeooeeooaospeeacoaoeecoeoeoeeveeaoeseoedogvuee ee eee e02ee @ 43 
5.0.2 Completing The Command eeoesvoeoe eo eoeoneeoveesvseoeeoeeveeonosnee 08080800 43 


Bick. “NOSCPERATION «cswicwiosinnad cccwwmbariowasieneewewmedesedeinnncactaa: 44 
Bed, WROTE: DATA cess neem ee soaaemnonmiesaoneeeseaceseaeeseiegemnnn 45 
5.3: 2READ DATA: steuc ncmeuwenuasaderecamumnedatosecssaeesncacevernsse 86 
5.4 REPORT CURRENT ADDRESS ...cccsscccccccccccccccccccsccccccsscces AT 
5.5 SEEK AND REPORT CURRENT ADDRESS ....ccccccceccccccccccccccssees 48 
5.6 START SEEK AND REPORT COMPLETION IMMEDIATELY ....cssecccccecees 49 
52] “DRIVE: RESET cas sare cincewagaisis sain s sieeaine sine cunisisaewesuiesearices. 50 
5.8 WRITE CONTROLLER PARAMETERS ....ccccccccccscccccccccccsccssoees Sl 


5.9 WRITE DRIVE PARAME TERS @eeoeeee@ ooo eceaevoeoeeesoeaeoeeaoseeoaesconvneeeeee eee ee @ 52 


-ivV- 


Rev. A. June 15, 1987 


XYLOGICS 752 Disk Controller User's Manual 


TABLE OF CONTENTS 

PAGE 
5.10 WRITE FORMAT PARAMETERS ....eccecceccccccccccceccscceccecsevees 53 
5.11 READ CONTROLLER PARAMETERS ...cccccccccccecceccecceccccsccscces 5A 
5.12 READ DRIVE PARAMETERS ...eccecceccecceccceccccsecsccsscsecesses 55 
5.13 READ FORMAT PARAMETERS ...cceccescccceccceccecceccecceccecesces 56 
5.14 READ DRIVE STATUS EXTENDED ....cccecccccccccecccccccceccecscces 57 
5.15 WRITE TRACK HEADERS ...sscsecececcescecccecceccecseceseeecesees 58 
Svl6: WRITE FORMAT «0.5... siesarewsaaeeune cewasmuweeseeusd eactawesacaaes. 09 
5.17 WRITE HEADER, HEADER VERIFY, DATA, AND DATA ECC ......eeeeeeeee 60 
5.16 “WRITE DEPOT MAP’.i< ecesoaneaverssaossceeeesaseackesecesteness 61 
5.19 WRITE DEFECT MAP EXTENDED .....cccccccccceccccceccecceccesseces 62 
5520. “READ TRACK HEADERS creseGacedde ee ssdecdienesnssasacestwekecees: 63 
S621. VERIFY DATA vuscecccedsewcsdeowe se eneteess ues ceuedt iavanekwees 04 
5.22 READ HEADER, HEADER VERIFY, DATA, AND DATA ECC ...ecceccesecees 65 
5423. “READ DEPRCI MAD’ scare cen aceectaene wae tae sage eeetecseseesas 06 
5.24 READ DEFECT MAP EXTENDED ......cccceccccccccccecceccecceececces 67 


5.25 DIAGNOSTICS @e@eeeaeeseaoeooeoeaoeooeaseeeeaeeeoeeeeeeaeeaeeeaeeevoeeoeeoeoeveeosveaoeeveoeaseeeaew eee @ 68 


SECTION 6: ERROR PROCESSING 
6.0 : (EAN IRAE S -1y-0) 919 'o alae oo sei 655 0 65006 Wawa 1050 AS hoe ew ahe sae we ees 69 
6.1 THE COMPLETION CODE eeeaoooeoseseoaoeeeeeoeeaesveeeoeoea@aeseoscoeoeoeeaoaeeseeoneavuecese © @ 69 


6.1.1 Completion Code Convention .ecccccccccccccccccccccvcces 09 
6.1.2 Completion Code Descriptions eeeeoeaeeeseoeae@eaeoeeaedodco@ea~esnoeoeeoseeoeeeee @ 70 


6.2 SOFT ERROR COMPLETION CODES Pie usd CRE aeie Oe iei eee ae 76 


Rev. A. June 15, 1987 


XYLOGICS 752 Disk Controller User's Manual 


TABLE OF CONTENTS 
PAGE 
6.3 ERROR CORRECTION CODE ...cccccccccccccccccccccccccccccccccccees 16 
Error Correction Code — Mode 0 cccccccccccccccccccceeee 16 


6.3.1 
6.322 Error Cor rection Code -—- Mode 1 eeeoeeeoeeeseeoe4@aeeeeeVeeo@eaeeeoeee @ 77 
6.3.3 Error Correction Code — Mode 2 ceccccccccccccccccccccce If 


6.4 FATAL ERROR CODE DESCRIPTIONS sateiedtesalased nies Ge Skee suaeeeee 77 


SECTION 7: A TUTORIAL IN PROGRAMMING THE 752 
7.0 GENERAL eeeeaecaneoceovoaneveaeooveoensveeveee ee eovoeaeevneeveeeoeeveeeeeoeeeeoeaoeceoeaoene es eee @ 719 
Tek NO OPERATION eeecoeoevoeeceavnonveeecooaonveeneeooeoeveeoeeeeoeeeeveeaeaevoevees een eeaeeae ee eee @ 79 


1.1 Allocating Memory For An IOPB ccccccccccccccccccccccccs BO 
1.2 Point the 752 to the IOPB wcccccccccccccccccccccsccccces BU 
els3 Starting the Operation c.cevecsscsicscceetescscesesevess 80 
To4 “152 OPELAClON: scewsd swe ceded sess taneewe wen cs wesne ewe sies 7OU 
1.5 Command Completion .cccscccccdcocvcccsccvessccseccvesecse OL 
1.6. Returned Values ivsseseecscscevecesecdevsvecdsssnvecces OL 


I~ ~~) ~~) 
e 


Lee READ CONTROLLER PARAME: TERS eeeoeoeacvoeveveenosveeeoveeeoeveeveenevoeeae eee e ee ee @ @ 81 
e Execute the IOPB eeeoeaoeeevavoeeoeoeeovneoeeeoeeeaeveevoeaoeaneoe0e on eoee eee @ 81 


7.201 
Teled 752 Operation eeceeoeeeeeveoeeoeoac eoeoeoeo eo eoeoeaoeeeveoe eevee eoeee eee eee @ 81 
TeZed The Returned IOPB eeeeevesvseveeoeveeeoeoee eevee oe eaeeaeoeooaoeauovoeea see ee @ 82 


TS WRITE CONTROLLER PARAME TERS eeeesoeoeaeeeeseaeaeeaeoeoneaeweaspmee@ascaeaoan@mnuoeo~oeoee9eenwde @ 83 

Leoek 752 Operation @eeeeoaoeosoeoeveoeeaeeeevnoeeuaeaeoeoeeeeaeneeeeoe eee ee eee @ 83 
7.4 READ/WRITE FORMAT PARAMETERS @eeeeeeoec eeoeeveveneaocovneeeneeaeaeoneneeeee eee 0 @ 84 
7.4.1 Execute the IOPB with InterruptS ...cccccccccccccvcccce G4 
7.4.2 752 Ope ration @eeeeaeeseovoeceoeoeveoeeaeeeoeseeeaeeeeeaeeoeeaeeeewoee@eeoeoeaee ee eee @ 85 
7.4.3 Command Completion eeoaoeoeeoeo eae eoeoeoeeeoseeoeeeeoeneeaevneoee eee eee eee 8 85 
7 4 4 Returned Values eeeaeeeaoevcoeaoeae ees eoaoeneneeaeaeeeoeeaeeoeosveoe0eeeee080200808 85 
15 READ/WRITE DRIVE PARAMETERS eeseeeoeoeeoaoevu ees aa oeveoedeveeedeo@eeeosneeee eee e ee 8 85 

1édel 752 Operation @eeeaeeoeoecoaoedceaoeeaeeeee00ee020e02eee2 020200C20820@e20002988609008428080 0 85 
7.6 FORMAT A TRACK @eeseaeeo ev eoee eoeevoeeeoeoeoeeaeoeeeeaeoeeeeeeeseeeveeeeoeoeeaeeee ee @ 86 


7.6.1 752 Ope ration eeoeeeeoc ac @e@eoeeveveeaseaeceseea een eoeeeveeveoeeeeee0202080808080 87 
- Vi- 


Rev. A. June 15, 1987 


XYLOGICS 752 Disk Controller User's Manual 


TABLE OF CONTENTS 
PAGE 
Tel READ TRACK HEADERS e@esoeee ooea eceoeeaoeeaeeaeveevoeeeoeeceaeneoeaew eevee eeoeeeee ee @ 88 


lelek 752 Ope ration eeseeovoooona ecoeoeeeoeoeeoeseeaeeaeeeeeaeaoeevne@eaeneea eee ee @ 89 
Tele2 Verifying the Data @eeoeoeoeeoeaooeoeaeeoaeeoeoeoeoeeoa@eoeaoeeeeaeonenaeoeeeee ee @ 90 


7.8 WRITE DATA eeee@eeoeoeeseevneeeeeeeeeeoeoevaeeeev@eae eeoeeeeaoac eo eoaoenw cua ooeoeaeeaeeaeee ee @ 91 


7.8.1 752 Operation @eeeeoeoovpeeoe oo eaeoeaeaeaoeeeoeoea eee eae eee eneaeoee ee @ 92 
1e8e2 Command Completion @e@eeaeeeecvoovoeoevoeeoeeeaooeaoeoeoeoeeoeaeeeoeesvee eee ee @ 92 


79 READ DATA eeeoaoeeseeeasceoeeenvn@e@ eee eoeaeoese ease oea eoeeeeeaeaeaeeaoeaeeaa eae eases e ee @ 92 
7.91 752 Ope ration @eeeoeeao cea eceoeewawovoeeseoeeceese eee eeaoeeaseaeeaeeseeoeoeee ee @ 92 
7.9.2 Command Completion @eeeeeoaove@eea eoeaoeooeaeoeaeveenvueeeaotecoeaeeeoe ee ee 8 6 92 
7-93 Verify Data eeeeoeaoea ea eeaeeaeaeeovoeeaeeooeaeovoeoeeaoeoeoaneaeoeaoeaonoeeneaoeaeee 8 93 

7.10 MULTIPLE SECTOR TRANSFERS @eeeeeaeoeaeespeaa eae eocaeaeea@ondooeaoec@aqovo@eseeacaeoeevneeaen eee ee 0 94 


711 SUMMARY @eeeee oo eeaeoeaoeaoeeoesneooaeoeoeasvoeoeoeaeoeeeeveeoaeaeeesce@eaeoeeaaeoeeoeaese ea @eoeaoeaeaeeaeae) 8 94 


SECTION 8: SPECIAL FUNCTIONS 
8.0 GENER PAE -sg55 6G, 56 so 6ca WW p70 hie wiiw 60600001 a o5e Wie SAO a WOOO Wee w eos 95 
8.1 READ DEFECT MAP @eeeeeoecea econ eosvpeoeeoevoeeeaeeaeoseoa@eaceaeae eee eaaea eae e@ceaeae eee ee 95 


1 (ne DELeCe “MAD 6.2.64.54 W565 Ges ee bose swinseewee cae w ee ese OO 
se. Read: the Derec’ Map: s6s6iiessceunssaw eve oeew oess cee ewe: 90 
S ‘VELiEY Che Data cievis os s0065seseese be esee ses eeseessews OO 
4 Determining the Location of a Defect ..ccccccccccccsccee GI 


8.2 FORMATTING Pt Oe eee One Or gee eee Manes Ge Gel ag may Sent ONT a ee” OP ey ey ene en 97 


8.2.1 Allocating Spare Sectors eeeoeeeec oeoeaeoeoeoeneneeaoeeaen eee eeeee @ 97 
8.2.2 Specify Sector Gap Size eeeaeeeveveeeev@eeoeoaoeo eon eeoeoeaee eee eeee @ 97 
8.2.3 Format Interleave e@eeeeoevoeeee eoeaeceaeoea eon e eevee eoedeoenoeeoeoee oe 8 100 


8.3 : MEDI DEFECT HANDLING COLCOCHCHC CECH SOHO OCHC HOSE EHOHOECSHOSEH OOOO OSTECOFEEZE 101 


A 
3.1 Slipping a Sector eeeecvoeeeoeooeoeo eon eanvneeoevoeenaeeoeaeoeenenee eee ee 101 
a Cylinder Sparing @eeoeeeseeeoeoeeoeoovneoecoeaeea ooo eoe eeaeoeeaeneaoe eee ee @ 103 
3.3 
3.4 


Track Remapping eeeoeeocoeseoeoeoe eoeaeeoeoeaeeaoaoevee@edsvzueeeeoeoeeoeeoe ee eee @ 104 
Recommended Remapping Procedure ...ccccccoccccccccceee LOD 


- vil - 


Rev. A. June 15. 1987 


XYLOGICS 752 Disk Controller User's Manual 


TABLE OF CONTENTS 
PAGE 

8.4  CHAINING AND MULTIPLE I/O REQUESTS ..cccccccccccccececcceccces LOS 
04, CHALAING <6 55556056 066660006 6 506 465666 GS Css ceeewes, 106 


8.4.1 
8.4.2 Multiple I/O Requests eo@eeoevc eco ooo 9eeaeeveoenueeono oe eee ee eee @ 106 
8.4.3 752 Ope ration ee@aeeeoeve eo eoeoeeoeaeeaeeoevoeeeeeoeaeoeoeaeeeeeee eee ed @ 106 


8.5 ERROR RECOVERY e@eeeeceonvneaevneoeoeaoeoeeooeeosneeaeeeooeoeeeeoeaeoeeaeeneeeeeeee ee 8 106 
Automatic Operation Retry eeaeeeseeooce#oscoaoeeosneaendeoeoeeoeeenee 8 @ 106 


8.5.1 
8.5.2 ECC Error Recovery eeesvoeeeceoeoeesdseoeaeeveeeseseeaeeoeeeoeeseeeasesnseoeeeee eo @ @ 107 
8.5.3 Using the Error Recovery OptionS .ccccccccccccccvcsccce LO/ 


8.6 MAINTENANCE MODE eeeeocvueeseeoevoeosee oes oeaeceeoeeaeoev eee eoeaneaoeaeeaoeeecee7e eee @ 107 


8.6.1 Register Use in Maintenance Mode @eeeoeevoeeceoeneovoeeevoeoeaeoee @@ 107 
8.6.2 Maintenance Mode Protocol @eeeeaoeocovaoeaoeeoevueeaoeveeasndeeoseeoneoeneeed @ 108 


8.7 MULTIPROCESSOR SUPPORT eeeeaeeoveeoeveeeovoeoeeeaeseeeeeeeeeveeeeeaeeeeeee eee @ 109 
8.7.1 Interrupts eeese@eeoevsevoecevoeeeeoeeeeeeee0202e2eee0eee00ee0egc 0e eee eee © 109 
8.7.2 Register Busy Semaphore eeeeeveveeceaeveeoeeeg2eeeee89002020006808080 6 110 
8.7.3 Address Modifiers eeeeeoeecveeaseveeeeeaoeeoeoeoeoeee@ee@ oe eaee0eeeanevese @ 110 

8.8 SOFIWARE CONTROL eeeeoeeoevoeeoeoeoeasveoeeeeeeeeeeoeveeeeoeoeooeoeee se ee0oe ee eee 8 @ 110 
8.8.1 Modifying a Single Parameter @eeesoeeaeeooeaoeeeoeeeeeee eeaeeeee@e@4@0 110 
8.8.2 Modifying a Group Of ParameterS .cccccccccccccccccccee 11D 
8.8.3 Parameter Reference POLNt cccccccccccccccccccccccccece Lil 

8.9 SCATTER/GATHER eeeeoeveee eo eoeeoeoeoeeeoeoeeceeaeeeeeaeee eae eeeese eee e ee eee @ lll 
8.9.1 Scatter/Gather Link List eeeeaeoeosvs oe oeee@eoeaa@ooeaeeaeeeoeeoe eee @ lil 
8.9.2 Setting Up a Scatter/Gather Transfer ...ccccccccccceee 112 
8.9.3 752 Operation eseeeooesc eo eoeoeaeoeeeeeeeeeeeeeeeeoeee@eooaee ee ee @ 113 

8.10 DMA THROTTLE / THROTTLE DEAD TIME eeeoeovoevoeeeoaeaeaeseoeeaeedeoedoeee ee ee @ 114 


8.11 IOPB CHECKSUM eeeeoaoevoe ee eooaeooeeveoe eoeoeeeaenceaoeoevneaoaen@a@eoeoeoeoeeoeeeeoeeee eee 8 114 


- Vili - 


Rev. A. June 15, 1987 


XYLOGICS 752 Disk Controller User's Manual 


TABLE OF CONTENTS 

PAGE 

8.12 FIXED/REMOVABLE MEDIA ..cccccccccccvccccccccccccccsccccccscces 114 
S.1Z2.1 Head OLESet cccsscccscccsvescscccccccsscccccoveccssoce L14 

8.13 EMBEDDED SERVO DRIVES .ccccccccccccccccccccccccvccsccscccesees ALS 
8.14 DUAL PORTED DRIVES scuaiaheeaseaatecuetsumaesucesseesee siete 115 
8.14.1 Software Write AcceSS Control .....cccccccccccceccccce 116 

8.15 READ/WRITE HEADER, HEADER VERIFY, DATA, AND DATA ECC ...ccecee 116 
8.15.1. ‘Simulating -an: BCC Brror .< vieseedeecsuwee ews Goecswwewesee 217 


8.16 RELEASE ON REQUEST @eeeeeeceaooevoeeoeeeoeveoeeenoeoeeveeveoeneaeevoeae een oeeaese ee 8 118 


SECTION 9: THEORY OF OPERATION 
9.0 GENERAL @eeeeoeoeecoao ea eoeoeaceaegpeoveseevoee eevee eeeoeespea ean eoeaeaeeaeoeeae eee 119 
9.1 Tne Hardware @eeseeecevcoeaoeveoeveeeveseeeeoeaosveeoeoeaeeeaoeeeeaeoeaeoeoa@eau@ eee ea@ecaneeee? 119 


VMEDUS” THECLE ACE s4.os.4.s4w6 64 aon ss eeweee ewes eee ewe 249 
Register Read/Write and Interrupt ..cccccccccccccccece LILI 
Tne MiGrocontroller: 6665sws% éc6ewdeweesee es ev ee ses eieee,20 
Direct Memory Access Controller ..cccccoccccccccccesee LL] 
Disk. Data Burt LEY sw bees Mew saw wins eswe se tseee sew ense ele 
DISK FEOME: BiG. svice-6 6 scssie ois 6 wie ws obs Cees ee eS secs ewe ewe bce 
SMD=E INCL LACCY 6.6% sisied o:0 4.66 OOEKS SENSO Swe weweweosees Lee 
POWELL UD 52076 65:4 wi sisis die dre'o 6 obo we Ws OS RSh wie en esewewweceen 123 
POWEE “GOWN: 5:66:35. scd 6-0 ied 06 ow oe bbe neewdslave wen wee saeee: bee 
QO: -SYSEEM-RESCE a s5i.5:6:5.-5'4:6'5-5:604.4 550 G66 esas wwe eee sewers Leo 


e 
bt ee 
e 


WOW WMH HO WH HO HH WO 
e e e 
e e e e 
MOON Om WN FF 


9.2 


i 


ICROCOD eeeeoce@evoanoanoe oven eeaenoeoeeovoeoeeeeovoe oa ea eee e eee aoe eee eee 6 123 


The: KErne b. in66ohdivs 65-6 dae. 0oe bscekessseauewseoeweee 25 
TS; AlO SOU? 062cais odscse esis oso s0oeo ae 60 swe cece cele wowsee se 224 
Ts Start Queue BMpty? <.6siwsesssseedeee sees ccaeevee: LZd 
Is Any IOPB Ready for Completion? @eeeeeeeoagaea0e2e¢eoeoeeeeoee 125 
Queuing IOPBs for Execution ..ccccccccccccccccescvecccee 125 


9 1 0 19 

e 

NO NO ND NO NO 
e 


& 
Ul & W Nb Ee = 


-~ ix - 


Rev. A. June 15, 1987 


XYLOGICS 752 Disk Controller User's Manual 


TABLE OF CONTENTS 
| PAGE 


9.3 PERFORMING A FUNCTION COCO COC EHEC ECO EEO OEE OE OOOH OOO CEES ECOL E FOES 125 


Normal Reads and WriteS .ccccccccccccecccccccvccsccese 120 
Seeks @eeeeeoeeac eo@qeoeoespe@a@qsoe oa oeveeeeeeeeeeeeocoaeaeoewoeoeeoeeeaeee eee @ 126 
DEIVG. (RESEE .. é:4:06-55.0 56.05. 00mse cs 650 666 ee awlew ne eeweeess. 120 
Write and Read Parameters eeeee@oe@oaoeao eceoseeeeeaoesoeaneg6eeeasesesegee ee 127 
Extended Read and Write Commands ..cccccccccccccecesee Lal 
Diagnostics eeeeeoeovooadecoea eeaeeeasoseoeeseeeseeoeeeeeeoeVaeaeeoeaoeeeee@eneee 8 ee @ 127 
Read Ahead Theory of Operation ..ccccccccccscccccccveee 128 
Dyna-throttle Theory of Operation ..ccccccccccccvccccee 128 


WH HH HO HO HO OO 
e 

WWW WWW WW WwW 
t 

WON AOU WN FE 


9.4 COMPLETING A FUNCTION eeoeeoeaeeeeoovoeeaoeoeoeoeoovneaee@ecoeospeaeeoecea3@aeoee eee ee 0 @ 128 


- SECTION 10: DRIVE INTERFACE 
10.0 GENERAL @eeeeesovoeaoeecoaonsveoe eevee ov eeveeeeeoeeeoseaeeveeeveeoeenoeee@aneneeen eo e880 8 129 
10.1 VMEbus INTERFACE SIGNALS eeoee@eoesveeaeoeoeoeoeneaoeoeea eoevo@eaeeeevoeveaeeaoeoeoee 02 ee @ 130 


10.2 EXTENDED STORAGE MODULE DRIVE INTERFACE eeeeeevevoeeoevoeeeoeeoeoeoee oe @ 132 


Rev. A. June 15, 1987 


XYLOGICS 752 Disk Controller User's Manual 


LIST OF ILLUSTRATIONS 


FIGURES 
2-1. 752 — Component Location ..ccccccccccccccescccce LO 
2-2. Base Address Jumper BLOCK ..ccccccccccccccccccee Ll 
2-3. | Jumpering Bus Request and Bus Grant Levels ..... 12 
2-4. Sample Part Number .icccccccccscedsescccsesecses LS 
7-1. Sample NOP IOPB ccccccccccccvcvcccccccccsvccecce IY 
7-2. Sample Read Controller Parameters IOPB ......e-. 82 
7-3. Sample Write Controller Parameters IOPB ........ 83 
7-4. Sample Read Format ParameterS IOPB ...cccccccesee 84 
7-5. Sample Write Drive Parameters IOPB ..ccccccccece 86 
7-6. Sample Write Format IOPB ..cccccccccccccccccccce O/ 
7-7. Sample Read Track HeaderS IOPB ..cccccccccccevee 89 
7-8. Sample Sector HeaderS ..cccccccccccccccccccccccse BW 
7-9. Sample Write Data IOPB ....cccccccccccccsescccee GL 
7-10. Sample Read Data IOPB ...ccccccccvccecccccccccece 93 
8-1. Defect Map Format .ccccccccccccccccccccccccscsere 90 
8-2. Extended Defect Map Format ..cccccccveccccccccce 90 
GS... SECCOr Gap SIZES cs swciccsecssecvevescsevcvecsnee 9S 
8-4, Sector Slip eoeeeeeeoeooeoeeeoeeeeeeeoeneeeeeeneeeeee 102 
8-5. Normal Header .cccccsecvcccscccccccccccsveseesess LUZ 
8-6. Header Marked Bad eeoeoeeceoeeeeeoeeoneeeeoeeeeeneeeee 102 
8-7. Header Marked Spare ..ccccccccccccccccccvccccees 103 
B=85. -RUNE HeaGer 66s si0sscedse secs evcessseceeeaesee: 10S 
8-9. Track Remap Header eooeeeceeceeoeoeeeoeoeeoec eee e eee ee 103 
8-10. Scatter/Gather Transfers ...cccccccccccccceceee 113 
9-1. The Microcode Kernel eeoeeceoecneeneeeeeoeeeeeeeceee 124 


2-1. Base AddreSs Selection .ccccccccccccccccccccccce Ll 
2-2. | PROM/PAL Part Number and Location ..ccccccccceee 13 
S-le. “REGISCEr OLESCUS: 6 65 sais bwesiese cies seeceweew eww (L/ 
3925 ‘Fatal: Ereor Codes: 2is0ekncieeceiseeseenseesaw es: 22 
4-1. Sub£unction Code Classes eoveeeeceeceoeceoeeeeeeeeeee 26 
4-2. Command/Subfunction CodeS .ccccccccccccccccccces 21 
4-3. Throttle Values eeceeeeveeeeoeeoeoeoeeeeeoeoeeeeeeeeeees 36 
4-4, Controller Type Codes eceoeoveeeeeoeoeeeeeeeeeoeeeeee 36 
4-5. Interléave: Factors: <é:6ise-esewiecessewwssecsessces: 41 
5-1. Command Completion Coeoeeveeeeoeeeoeoeeeeeeeeoeoeeveeseee 43 
— 5-2. Extended Drive Status eeeeoeonvoeaeaecsoeoeeoeaoecenoeeoeeeeeeose @ 57 
6-1. Recovery Codes eeeeoeoeaeooao@a eee eeaeo econ e@oaduouo@eaeoecoee oe @ 69 
6-2. Summary of Completion CodeS ..ccccccceccccceccee 10 
8-1. Register Use in Maintenance Mode .....cccccccee 1O/ 
8-2. Scatter/Gather Link LiSt ...cccccccccccvccvccccee Lil 
8-3. Link List Field Values eeeeeoeeoocaeeaeseaeaoea@eeeeeeee od @ 112 
8-4. Throttle Dead Time Values eseeeevneceeeoeeeeeenee 114 
8-5. EC32 VSe Returned Data eoeevoeoeeeeeeeeoeeeeeeeeeee 117 
8-6. Simulated 2-bit Error Crossing Byte Boundaries 118 


Rev. A. June 15, 1987 


XYLOGICS 752 Disk Controller User's Manual 


1.0 


1.1 


Lelek 


1. VMEbus is a trademark of the VMEbus International Trade Association. 
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SECTION 1: SPECIFICATIONS 


GENERAL 


The Xylogics Model 752 disk controller accommodates up to two SMD-E 
interface disk drives to VMEbusl systems using VME 9U backplanes 
(accepting a 15.75- by 14.44—-inch board size). 


USING THIS MANUAL 


This manual provides two software reference cards for fast 
reference of the IOPB structure and codes (see insert). Section 2 
describes how to install and test the 752; Section 3 describes the 
752 registers; Section 4 describes the JIOPBS; and Section 5 
describes the 752 commands. Section 6 describes error processing; 
Section 7 is a programming tutorial; Section 8 explains the 752's 
Special functions; Section 9 describes the 752 theory of operation; 
and Section 10 includes drive interface information. 


nD ati 


This manual uses the following mnemonics: 


AIO Add IOPB 

AIOP AIO Pending 

AM Address Modifier 

ASR Automatic Seek Retry 
AUD Auto-update 

C450 450-Compatible Format 
CHEN Chain Enable 

CRIO Clear Remove IOPB 
CRBS Clear Register Busy 
CTYP Controller Type 

DFLT Drive Fault 

DMA Direct Memory Access 
DPB Dual Port Busy 

DRA Disable Read Ahead 
DRDY Drive Ready 

EC32 32-Bit ECC 

ECC Error Correction Code 
ECCM Error Correction Mode 
EDT Enable DMA Timeout 
ERRS Error Summary 

ESD Embedded Servo Drive 
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Abbreviations (continued) 


Fatal Error 

First In/First Out Buffer 
Fixed/Removable Media 
Notation for Hexadecimal Values 
Hold Dual Port 

IOPB Checksum 

Input/Output Parameter Block 
Maintenance Mode Active 
Maintenance Mode 
Non-privileged Register Mode 
On-cylinder 

Overlap Seek Enable 

Prom Number 

Priority Select 

Read Ahead IOPB 

Retry Before Correction 
Register Busy Semaphore 
Remove IOPB 

Register Maintenance Mode 
Release On Request 
Scatter/Gather Mode 

Seek Error 

Throttle Dead Time 

Throttle 

Transfer Mode 

Write-protect 


DESIGN RELIABILITY 


Xylogics implements the following features to minimize 
likelihood of product failure: 


O 


O 


Design for worst case voltage and temperature. 
Extensive evaluation testing. 

Low parts count through extensive use of custam LSI. 
Buffer parity for continuous error checking. 
Low-stress design on all components. 

All components burned-in. 

One card; resides in backplane or expansion chassis. 


Controller is power-cycled under thermal stress during 
test. 
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PHYSICAL 


PACKAGING -- The 752 completely reSides on one printed circuit 
board (PCB). 


DIMENSIONS -~ The 752 is a 3 by 3 Eurocard, measuring 14.44-inches 
high by 15.75-inches deep (366.7 mm by 400 mm). It is identical in 
form-factor to the VME triple high-triple wide PCB. 


SHIPPING WEIGHT —— 5 pounds (2.3 kg). 


FRONT PANEL -- Xylogics offers the 752 with an optional front 
panel. 


CONNECTORS -- The 752 uses a 60-pin connector for the "A" cable, 
and two 30-pin connectors for the "B" cables. The SMD connectors 
are on the edge of the board facing out; they protrude through the 
optional face plate. The optional straight connectors do not 
protrude the face plate. 


ENV IRONMENTAL 


The 752 environmental requirements are 0 - 55°C, with a maximum 
relative humidity of 90% (without condensation). Air flow across 
the board must maintain a maximum temperature differential of 70°C 
to prevent hot spots. 


ELECTRICAL 
POWER -—- The 752 uses 4.1 amperes at +5 volts DC (VDC), and 0.6 
amperes at -12 VDC. ‘The -5 volts for the differential transceivers 


is derived on-board. 


TOLERANCE — Voltages must be within plus or minus five percent 


GROUNDING -- Common earth ground must be established between the 
disk drives and the CPU chassis, backplane, and expansion cabinets. 
SYSTEM RELATED SPECIFICATIONS 

DATA BUFFERING -- The 752 has a FIFO buffer that is 8K-bytes long 
and incorporates parity error detection. Data can be put into one 


end of the FIFO and simultaneously removed at the other end; there 
are no delays associated with filling and emptying the FIFO. 
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SYSTEM RELATED SPECIFICATIONS (continued) 


READ AHEAD — Causes the 752 to complete an initial read and then 
continue reading ahead, thereby satisfying future reads with data 
from the FIFO. | 


FORMAT -- The 752 Format command formats a specified number of 
tracks. Use the Read/Write Track Headers commands to incorporate 
custom interleaving schemes. Standard interleaving is 1:1; 2:1 to 
15:1 interleaving is software programmable. 


MEDIA DEFECTS — The 752 has several methods for remapping bad 
blocks. One method leaves spare sectors on each track that can 
slip bad sectors with Read/Write Track Headers commands. An 
alternate method has the spare sectors on the last part of the 
maximum head. The 752 also remaps entire tracks. This reduces the 
total number of Spare sectors required with minimal affect on 
system performance. 


READ DEFECT MAP FEATURE — The 752 can read the manufacturer's 
defect information directly from the unformatted disk. 


STATUS LEDs -— The 752 implements two status LEDs. Lil (BSY) 
indicates the controller is active; L2 (ERR) indicates the on-board 
diagnostics did not complete successfully, or an error occurred, 


SCATTER/GATHER —- The 752 supports Scatter/Gather on Read and Write 
commands. The controller can gather data from various memory 
locations and transfer it to the buffer for use in a Write command; 
it can scatter the data out from the disk drive to the appropriate 
memory locations with a Read command. To execute a scatter/gather, 


software issues a normal Read or Write command along with a DMA 


list that contains a memory address and the number of words to 
transfer to/from that location. The smallest granularity of 
scatter/gather is a 16-bit word. 


ON-BOARD DIAGNOSTICS -——- The 752 runs an extensive on-board 
diagnostic routine upon power-up or a bus reset. If an error 
occurs during this test, the 752 posts the failure in a special 
error register. 
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SYSTEM RELATED SPECIFICATIONS (continued) 


ERROR DETECTION AND CORRECTION -—- The 752 supports a 48-bit data 
ECC with a redundant header check; it optionally supports a 32-bit 
ECC on the header and data (for supporting earlier controller 
formats, 1.e., 451). Software controls automatic detection and 
correction. 


The 48-bit ECC detects an error burst up to 28-bits long, and 
corrects error bursts up to 14-bits long. The 32-bit ECC detects 
an error burst up to 22-bits long, and corrects error bursts up to 
ll-bits long, assuring data integrity. 


IMPLIED SEEK CAPABILITY -— Data transfer instructions contain an 
implied seek. Data transfers cross sector, head, and cylinder 
boundaries aS required (spiral read/write). 


OVERLAP SEEKS -—- The 752 supports overlap seeks. When overlap 
seeks are enabled, the 752 may have both drives simultaneously 
seeking to the appropriate cylinders. 


DIAGNOSTIC SUPPORT -- Comprehensive set of stand-alone diagnostics 
written in 'C' are available. 


DISK DRIVE RELATED SPECIFICATIONS 


PHYSICAL DRIVE INTERFACE — ‘The 752 supports the Extended SMD 
Interface ([SMD-E]; See the Control Data Corporation (CDC) 
64712402, Revision A, and Fujitsu BO3P—4760-0101A). 


INTERFACE DATA RATE — The 752 supports a maximum disk data rate of 
2.4 megabytes per second (MBS). ‘The 752 supports this data rate at 
a l:l interleave factor. This allows continuous data transfers, 
crossing sector and head boundaries with no loss of disk 
revolutions (assuming the controller has enough bus time to | 
transfer the data). 


MIXED DATA RATES -—— The 752 mixes drives with different data rates 
(i1.e., 1.2 MBS, mixed with 1.8 MBS, or mixed with 2.4 MBS drives). 


EMBEDDED SERVO DRIVES -—- The 752 supports embedded servo drives. 
NUMBER OF DISK DRIVES — The 752 supports up to two SMD-E drives. 


DISK SECTOR FORMAT -—— The 752 sector format includes a header field 
separated from a data field by a splice area. 
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DISK DRIVE RELATED SPECIFICATIONS (continued) 


HEADER FORMAT -- Header contains sector, head, cylinder address, 
and header ECC or a redundant header. 


CABLING -—- The 752 uses standard SMD flat cabling or equivalent. 


DUAL PORT -- The 752 supports dual port drives. 


VMEbus RELATED SPECIFICATIONS 
VME COMPLIANCE NUMBER — IEEE P1014/D1.0. 
TRANSFER MODE -- Direct Memory Access (DMA). 


DMA THROTTLE CONTROL -- Each time the 752 becomes bus master, it 
executes DMA transfers to or from system memory up to the max 
throttle limit or the number of words/longwords available in the 
FIFO buffer. 


DYNA-THROTILE -—- During a Read command, each time firmware executes 
the DMA scheduler, the 752 calculates the amount of data currently 
in the FIFO and DMAs from one to seven sectors to system memory. 
Dyna-throttle does not override the normal throttle and throttle 
dead time features that tune system bus activity. 


DMA DATA TRANSFER RATE — The 752 has a maximum transfer rate of 18 
MBS based on 30 nanoseconds (ns) memory response time (assuming 
longword mode transfers). Typically, the 752 transfers data at a 
rate of up to 10 MBS based on 200 ns memory response time (assuming 
longword mode transfers). 


DMA DEAD TIME — The 752 supports a programmable throttle dead time 
between throttle bursts. This prevents the 752 from taking over 
the bus and allows time for other DMA devices to access the bus. 


DATA TRANSFER LIMIT -— Data transfer length, from 1 to 65,535 
sectors with a single IOPB. 


BUS COMPATIBILITY -— The 752 is compatible with the standard 
VMEbus. 


ADDRESSING CAPABILITY — The 752 supports master A32, and slave 


Al6, as per the VMEbus Specification. As a slave, the 752 responds 
to address modifiers 29H and 2DH (software programmable). 
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VMEbus RELATED SPECIFICATIONS (continued) 


DATA WIDTH -- The 752 supports D1l6 and D32 as per the VMEbus 
Specification. 


RELEASE ON REQUEST — Software programmable; the 752 releases the 
bus at the request of other peripheral devices. 


RELEASE WHEN DONE -- ‘The 752 releases the bus after each bus 
access. 


BUS REQUEST LEVELS — The 752 supports four bus request levels 
(Jumper selectable). 


EARLY RELEASE OF BUS BUSY/ — The 752 does not support early 
release of Bus Busy/. 


INTERRUPI PRIORITY -— Software programmable interrupt level and 
vector. 


CONTROLLER I/O PARAMETER BLOCK (IOPB) LENGTH — 30 bytes. 


CONTROLLER REGISTERS — Seven 8-bit I/O Registers; byte or word 
addressable. Only eight bits respond during word access. 


SOFIWARE RELATED SPECIFICATIONS 


SOFPIWARE INTERFACE — ‘The 752 supports a high level software 
interface that allows host software to use the same method to add 
IOPBs to a chain while the controller is busy or while it is free. 


software Interface 


The software interface includes seven byte-wide registers. Four of 
these bytes comprise the VME Address Register, the fifth byte is 
the Address Modifier Register, the sixth byte is the Control and 
Status Register (CSR), and the last byte is the Fatal Error 
Register (the 752 returns the fatal error codes in this register). 
The CSR includes two bits that are very important to IOPB 
processing: Add IOPB (AIO) and Remove IOPB (RIO). 
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Software Interface (continued) 


The IOPB is a block of command and status information; it includes 
the disk address, the bus address, and the type of operation to be 
performed. The software driver sets up the IOPB in memory, sends 
the IOPB address to the VME Address Registers, and sets AIO. After 
the 752 receives the IOPB address it resets AIO. The 752 then 
performs the IOPB function and, upon completion or error, updates 
the IOPB status and sets RIO. The VME Address Registers point to 
the completed IOPB; the software driver reads the address and then 
resets RIO. 


Software may add IOPBs to the queue, providing AIO is clear, by 
writing the IOPB address to the address registers and setting AIO 
(regardless ot the 752's busy status). 

PROGRAMMABLE FEATURES 

© Software Controlled Interrupt or Polled Operations. 

O Software Programmable DMA Parameters. 


fe) Software Programmable Drive Size Parameters. 


re) Software Controlled Transfer Retry/Correction. 
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SECTION 2: INSTALLING AND TESTING THE 752 


GENERAL 


Section 2 describes how to unpack, configure, install, and test 
your 752 controller. 


UNPACKING AND INSPECTION 
Inspect the Shipping Carton 


Inspect the carton for possible shipping damage. If you determine 
there is damage, do not unpack the unit. Notify Xylogics and the 
freight carrier immediately. 


If no damage iS visible, carefully unpack the 752. Save the carton 
and other packing material for possible later use. 


Contents 


The 752 is a single printed circuit board. Optional items include 
a manual and/or software on a floppy disk, or 1/4-inch magnetic 
tape cartridge. 


If any items are missing or damaged, please contact Xylogics at one 
of the following telephone numbers. 


United States: (617) 272-8140 
United Kingdom (Milton Keynes): 44-908-569444 


Handling Precautions 


Observing proper handling precautions minimizes the risk of 
damaging the 752 with electrostatic discharge. When transporting 
the 752, use an antistatic bag, antistatic bin, or the original 
shipping carton and packing material. Personnel handling the 752 
should observe proper grounding methods including, but not limited 
to, wrist bands, heel straps, and antistatic mats. 


Inspect the 752 
Inspect the 752 for socketed parts that may have loosened during 


shipment. Make sure all parts are firmly seated in their sockets. 
If any parts need reinsertion, observe proper orientation. 
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CONFIGURING THE 752 


The 


You can configure the 752 with several jumper options. 


following subsections describe these options. 
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26261 Base Address Selection 


Jumper block JA controls the base address. Table 2-1 shows how to 
set the jumpers for commonly used base addresses. Inserting a 
jumper makes the 752 respond to a 0 on that address line; removing 
a jumper makes the 752 respond to al. Connect the jumper between 
Similar pin numbers on each block. (The 752 uses bits 1 through 3 
to determine which register is being accessed.) The 752 is an Al6 
Slave, and responds to address modifier 02DH, and optionally 029H. 


* These two pins are test points, not address jumpers 


Figure 2-2. Base Address Jumper Block 


Screen Label —> F E DC B AQ 8 7 6 5 4 

Address: 

0100 I III I I I O I III 

0800 I III O III Tr. 2 of 

EE40* OOO! OOO! I Om1IitI 

EE80 Oo0oOOii]I Oo O0OOii!I O III 
O = Out; I = In; 


* Standard Factory Configuration 


Table 2-1. Base Address Selection 
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2.202 


20203 


Bus Request and Bus Grant Lines 


The 752 uses the Bus Request and Bus Grant lines to become bus 
IMaster. In VMEbus arbitration, there are four Bus Request/Grant 
levels: 0 through 3. The 752 drives one Bus Request line 
according to the jumper scheme you choose. ‘The arbiter drives the 
four Bus Grant In lines:  BGOIN* through BG3IN*. If the 752 
receives a Bus Grant, and is not requesting the bus, it passes the 
grant by driving the appropriate Bus Grant Out line: BGOOUT* 
through BG3OUT*. 


Select a request level by jumpering one Bus Request (BRO* through 
BR3*), one Bus Grant In, and one Bus Grant Out line to match the 
selected request level. Jumper the remaining Bus Grant In/Out 
lines so that the incoming signal passes through the board (i.e., 
jumper BGxIN* to BGxOUT*, where x represents the remaining grant 
levels). 


For example, Figure 2-3 shows the jumpering scheme for level 3 
(Figure 2-3A shows the jumper blocks as they actually appear on the 
board; 2-3B is labeled for this example): jumper JB4 to JB8; then 
jumper JC4 to JC8, and JD4 to JD8. Jumper the remaining Grant 
levels from JCS to JD1, JC6 to JD2, and JC7 to JD3. #£Factory 
configuration: Bus Request Level 3. 


NOTE 


Certain processors (i1.e., Sun Microsystems) only 
Support Bus Request Level 3. 


BUS RQST BGOUT BG/N 


BR OUT IN 
L_ BG —J 


Figure 2-3A. Actual Board Layout Figure 2-3B. Sample Jumpering Scheme 


Figure 2-3. Jumpering Bus Request and Bus Grant Levels 


Parallel Arbitration 


If you are using the 752 in parallel arbitration, and the Bus Grant 
Out lines must be isolated from the next slot's Bus Grant In lines, 
remove all jumpers between JC 5-8 and JD 1-4. 
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2.3 


2.4 


2.6 


2] 


Rev. A. 


MAINTENANCE MODE LOCKOUT JUMPER 


Installing jumper JE 1-2 gives you unrestricted use of the 
maintenance mode. 


When jumper JE 1-2 is removed, you may only execute the diagnostic 
portion of the maintenance mode. (The non-diagnostic portion of 
the maintenance mode is proprietary to Xylogics and subject to 
change without notice.) 

SELF TEST DISABLE 

When jumper JE 3-4 is installed, the 752 does not execute the self 
test on power-up. 


PROMS AND PALS 


Location Part Number Type 
D8 180-002-173 EPROM 
L3 181-001-015 PAL 
M3 181-001-016 PAL 
D2 181-001-017 PAL 
E2 181-001-041 PAL 


Table 2-2. PROM / PAL Part Number and Location 


LIGHT EMITTING DIODES 


The 752 has two light emitting diodes (LEDs). Ll (BSY) is the Busy 
LED; when lit, the 752 is active. 12 (ERR) is the Error LED. 
During power-up, L2 lights for a moment (indicating the self test | 
1s running), and goes off; if L2 stays on, a fatal error occurred. 


BOARD LABELS / REVISION CONTROL 


All Xylogics controllers use various revision control labels. This 
information is important when discussing configuration issues with 
us. Please familiarize yourself with your board revision levels 
before contacting us. 


752-101-01 
Product _.__—i|— ls] 


Configuration Revision Level 


Figure 2-4. Sample Part Number 
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2.8 PREPARING THE COMPUTER SYSTEM FOR INSTALLATION 


The backplane of your system must provide a VMEbus slot for the 
752. The slot must be capable of handling a bus master, and the 
power source must handle the power consumption of the entire 
system, including the 752. 


2.8.1 Backplane Jumpers 


Remove any jumpers that short, or cause the Interrupt Acknowledge 
(IACK IN/OUT) and DMA Grants (BG 0-3 IN/OUT) to bypass the slot in 
which you are installing the 752. 


2.8.2 Card Cage Slot 


The card cage must have a slot at the proper DMA priority available 
for the 752. The 752 uses DMA to transfer data and IOPBs. 
Placement of the 752 in the DMA priority chain may be critical. 
The amount of bus bandwidth it uses will be high at times; this may 
affect other boards in the system. Likewise, other boards may not 
allow enough time for the 752 to DMA enough data to keep up with 
the disk; consider this when choosing a slot. If the 752 does not 
get a high enough priority, then its DMA falls behind what the disk 
requires, and it has to wait until the next revolution before 
continuing the transfer. If the 752 priority is high, it gets 
enough DMA time, but other boards having insufficient buffers may 
starve from lack of DMA time. The priorities must be balanced for 
your system to work properly. 


2.8.3 Power Considerations 


The 752 affects the power consumption of the entire computer 
system. The 752 uses +5 volts for logic and -12 volts to provide 
-5 volts to power the differential drivers/receivers for the SMD 
interface. Be sure the power supplies can handle the entire power 
load. Readjust the voltages after plugging in the 752. A power 
supply that is just adequate may cause intermittent and unusual 
problems due to noise generated by occasionally going into 
overcurrent protection. 


Limits: +5 volts (4.75 to 5.25 volts) at 4.1 amps; 
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2.9 


2-91 


2-9-2 


2.9.3 


2.9.4 


Rev. A. 


PREPARING THE DISK DRIVE FOR INSTALLATION 


Follow the manufacturer's instructions for unpacking and inspecting 
the disk drive. 


Configure the drive for use with the 752. This entails setting up 
Such parameters as the unit select, number of sectors per track, 
and ensuring the sector and index pulses are provided on the "A" 
cable. Consult the drive manual for the exact method of 
configuring your drive. 


Drive Unit Select 


A plug on the front of the drive, or switches on one of the drive's 
internal circuit cards, usually selects the drive unit number. The 
752 accesses drives with unit numbers ranging from 0 through 7. 
Set the first drive to Unit 0. 


Number of Sectors Per Track 


Switches on one of the drive's internal circuit cards usually 
select the number of sectors per track. The 752 standard format 
uses 88 bytes of overhead per sector. This is a nominal number 
derived from the defaults set at the factory. See Section 8.2 for 
a more detailed description. 


If you are using the sector slip feature, the number of sectors 
available to the program is the total number of physical sectors on 
the drive less the spares (see Section 8.3 for more information on 
media defect mapping). 


Many disk drives have a runt sector (a very small sector at the end 
of the disk). The 752 requires that all sectors except the runt 
are formatted. The minimum runt size is six bytes. 


sector and Index Pulses 


Both the "A" (Control) cable and the "B" (Radial) cable can provide 
the sector and index pulses. Disk vendors usually provide drives 
with sector and index on the "A" cable. The 752 requires the "A" 
cable to carry sector and index. 


Tags 4 and 5 
Some disk drives use the spare lines (see Section 10) for 
maintenance functions (Tag 4). Other disk drives use the spare 


lines for Extended Cylinder bits (Bit 10). The 752 supports both 
options; configure the drive for its intended use. 
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2.9.5 Extended Cylinder Addressing 


~here are two methods for addressing cylinders beyond 1023. 
Xylogics supports the method that uses the spare lines on the "A" 
cable as cylinder address bit 10. (The 752 does not support the 
alternate method of using the upper bits of the common interface 
bus and Tag 2 [Head Tag].) 


2.10 INITIAL TESTS 


This section relies upon your familiarity with your computer 
system's monitor and diagnostics. 


2.10.1 #Power-up and Self Test 


The 752 initiates a self test upon power-up. The Error LED (L2) 
lights for a moment, and then goes off. If L2 remains on, the 
board is not functioning properly (the Fatal Error Register may 
indicate the nature of the problem). When L2 is on, SYSFAIL is 
asserted on the VMEbus. Contact Xylogics for further assistance. 
(Check the power supply voltages to ensure they are within limits 
[4.75 to 5.25 volts, and -11.4 to -12.6 volts]). 


2.10.2 Drive Ready 
Spin the drive up and wait for it to become ready. Issue a Read 
Drive Parameters command. The Drive Status byte indicates the 
drive status at execution time. If DRDY is clear, recheck the 
drive cable connections and try again. If you are still unable to 
get the proper status, check the -12V supply on the bus. If the 
problem persists, check the disk drive with an off-line tester. 
2.11 DIAGNOSTICS 
When you run your diagnostics: 
© Format the disk with either a diagnostic or format program. 


oO Run a full pass of your diagnostic (or determine that the system 
is working properly). 


o Cable and test any additional drives. 
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3.0 


3.1 


3.2 


SECTION 3: THE 752 REGISTERS 


GENERAL 


The 752 programming interface is based on the use of seven, 
one-byte long, I/O registers. The bus address jumpers define the 
base address of the register set. Table 3-1 lists the registers 
along with the address offset from the base address. ‘The 752 
responds to either bytes or 16-bit words; when it responds to 
words, only 8 bits are valid. 


The registers have one function when read, and another when 
written. The following subsections detail their definitions. 


Register Offset 
IOPB Address Byte 0 (Least Significant Byte) 1 
IOPB Address Byte 1 3 
IOPB Address Byte 2 5 
IOPB Address Byte 3 (Most Significant Byte) 7 
IOPB Address Modifier 9 
Control and Status Register B 
Fatal Error Register D 


Table 3-1. Register Offsets 
IOPB ADDRESS REGISTERS 


The first four registers define the 32-bit address of an IOPB or 
IOPB chain. When these registers are written, the 752 interprets 


it as the address of the IOPB or IOPB chain to be executed. When | 


read, and the Remove IOPB (RIO) bit is set, the registers point to 
the IOPB or IOPB chain just completed by the 752. 


The protocol for reading and writing this address register is 
defined by the use of the Add IOPB (AIO) and Remove IOPB (RIO) bits 
in the Control and Status Register (see Section 3.3). 


IOPB ADDRESS MODIFIER 


This register defines the IOPB address modifier. Address modifiers 
are used for many purposes, such aS memory mapping, privilege 
levels, and addressing’ range. Please consult the VMEbus 
Specification for more information regarding address modifiers. 
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3.2 IOPB ADDRESS MODIFIER (continued) 
Section 3.3 defines the protocol for reading and writing this 
register. 
IOPB ADDRESS MODIFIER 
I7161514/3 12/1101 
RESERVED a 


ADDRESS MODIFIER... t—“‘(‘CSO™COCOC;C;C;C™C*dSCisé*dT#NNSN$#N:SNCNNN L™™—J_ 


Bit MM ; c itd 
7-6 RESERVED. 


5-0 AM ADDRESS MODIFIER -— Most systems use the standard 
AM code of 3D. (See the VMEbus Specification. ) 


3.3 CONTROL AND STATUS REGISTER 


When written, this register provides the host with control of the 
752 operation; when read, it provides the host with 752 status 
information. Section 3.3.1 defines the bits in this register when 
written; Section 3.3.2 defines the bits when read. 


3.3.1 Control Register (Write) 


CONTROL REGISTER (Write) 


[716/514 ]3]2]1 {0 4] 

REGISTER MAINTENANCE MODE ee ee ee ee ee | 
RESERVED ee | 
ENABLE MAINTENANCE MODE aE | 
a eee ee ee ee eee 
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Pee Control Register (Write) (continued) 


Bit M ; , toti 


7 RMM 
6 

5 MM 
4 

3 CRST 
2 AIO 
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REGISTER MAINTENANCE MODE - When RMM and MM are 
set, the values previously written in all the 
registers (except the CSR) are echoed back. 


RESERVED. 


ENABLE MAINTENANCE MODE - Setting MM and AIO 
places the 752 in Maintenance mode. This mode 
supports a different Register protocol and is used 
aS a diagnostic tool. Section 8 outlines the 
Maintenance mode. 


RESERVED. 


CONTROLLER RESET - CRST signals the 752 
microprocessor to perform a "soft" reset; it 
deselects all the drives (and releases dual port), 
stops the DMA and disk sequencers (potentially 
during sector transfers), and cancels any IOPBs in 
the queue. When the Controller Reset completes, 
the 752 resets the CSR to zero. CRST does not 
initiate a power-up self test. 


NOTE 


A Controller Reset takes up to 
one second to complete. 


ADD IOPB - When set, the 752 executes the IOPB 
(chain) at the address pointed to by the IOPB 
Address and Address Modifier Registers. As soon 
as the host sets AIO, the 752 sets AIO Pending 
(AIOP) in the Status Register (indicating the 752 
has received AIO, but has not yet processed the 
new chain's address). AIOP is negated in the 
Status Register after the 752 internally stores 
the new (chain) address. The 752 can store up to 
41 IOPB addresses in this manner. Clearing AIO if 
AIOP is set violates the register protocol. 
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Sedek Control Register (Write) (continued) 


Bit M ic I tot; 


1 CRIO 


CLEAR RIO - The host sets CRIO to clear RIO in the 
Status Register. Typically, the host sets CRIO 
after it reads the address of a completed IOPB 
Chain from the IOPB Address and Modifier 
Registers. Clearing RIO enables the 752 to update 
the IOPB Address and Modifier Registers with the 
address and address modifier of a newly completed 
IOPB (chain). Clearing RIO if it is not set in 
the Status Register violates the register 
protocol. 


CLEAR RBS - The host sets Clear Register Busy 
(CRBS) to clear RBS in the Status Register. 
Clearing RBS releases the registers for use by 
another host (see Section 8.7.2). (CRBS is only 
relevant in a multiprocessor environment.) 


3.3.2 Status Register (Read) 


BUSY 
FATAL ERROR 


eae ne ee ee ee | 
MAINTENANCE MODE ACTIVE sees | 
| 


RESERVED 


CONTROLLER RESET ACTIVE 


AIO PENDING 
REMOVE IOPB 


REGISTER BUSY SEMAPHORE 


STATUS REGISTER (Read) 


I71@ITS5 14/13 |27;1 101 


Bit M r cot 


7 BUSY 
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BUSY - The 752 is executing an IOPB. The 752 sets 
BUSY when it clears AIOP to acknowledge the first 
IOPB address; it clears BUSY after completing all 
the IOPBs with no new ones pending (within 500 
microseconds of the host clearing RIO on the last 
IOPB). ‘The 752 redefines this bit in Maintenance 
mode (see Section 8.6). 
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3.3.2 Status Register (Read) (continued) 


Bit M ' r oti 


6 FERR 
5 MMA 
4 

3 RSTA 
2 ATOP 
1 RIO 

4) RBS 
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FATAL ERROR - The 752 detected a fatal hardware 
error (a fatal error asserts SYSFAIL). A 
Controller Reset clears this bit. The Fatal Error 
Register contains more specific information. ‘The 
752 asserts FERR under the following conditions: 


(1) Maintenance Mode Test Failure; 

(2) Power-up Self Test Failure; 

(3) IOPB Checksum Miscompare; 

(4) IOPB DMA Fatal; 

(5) IOPB Address Alignment Error; 

(6) Firmware Error; 

(7) Illegal Maintenance Mode Test Number; and 
(8) ACFAIL Asserted. 


MAINTENANCE MODE ACTIVE - When set, the 752 is in 
Maintenance mode (see Section 8.6). 


RESERVED. 


CONTROLLER RESET ACTIVE - The host set CRST in the 
Control Register and the 752 is resetting itself. 


AIO PENDING - When set, AIO has been set in the 
Control Register, but the 752 has not acknowledged 
its receipt. When clear, AIO may be set again. 


REMOVE IOPB - The 752 sets RIO after completing an 
IOPB (chain) and placing the address in the IOPB 
Address and Address Modifier Registers. 


After the host reads the address and modifier, it 
must clear RIO by writing Clear RIO (CRIO) in the 
Control Register. 


REGISTER BUSY SEMAPHORE - RBS allows multiple 
hosts to share access to the 752 registers without 
Simultaneous access (see Section 8.7.2). (RBS is 
only relevant in a multiprocessor environment. ) 
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3.4 FATAL ERROR REGISTER 


If a fatal error occurs, the 752 returns the appropriate Completion 
Code in this register. Table 3-2 lists the fatal error codes; 
Section 6.4 describes them. 


E0 Reserved 

El IRAM Self Test Failure 

E2 Reserved 

E3 Maintenance Test 3 Failure (DSKCEL RAM) 

4 Maintenance Test 4 Failure (Header Shift Register) 
E5 Maintenance Test 5 Failure (VMEDMA Registers) 
E6 Maintenance Test 6 Failure (REGCEL Chip) 

E/ Maintenance Test 7 Failure (Buffer Parity) 

E8 Maintenance Test 8 Failure (Disk FIFO) 

E9-EF Reserved 

FO IOPB Checksum Miscompare 

Fl IOPB DMA Fatal 

F2 IOPB Address Alignment Error 

F3 Firmware Error 

F5 | Illegal Maintenance Mode Test Number 

F6 ACFAIL Asserted 


Table 3-2. Fatal Error Codes 
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SECTION 4: IOPB DESCRIPTION 


4.0 GENERAL 


The Input/Output Parameter Block (IOPB) passes messages between the 
752 and host software: software passes the type of transfer, disk 
address, data address, and count to the 752; the 752 returns the 
transfer status and, if AUD is set or an error occurs, the ending 
addresses upon command completion. This section begins with the 
standard IOPB for most data transfer commands and follows with 
variations of the IOPB. 


4.1 STANDARD IOPB 


The 752 uses the standard IOPB for data transfer commands and some 
general purpose commands. 


STANDARD IOPB 


ee a ae ee ace ae 
_leres] | [Oone) | CHEN] | 


_ ot 
02 CSE 


NTERNAL STATUS 


N 


04 
ig | [RoP| | [Psee} | of SQ 
06 INTERRUPT LEVEL] | 


|NEXT |OPB ADDRESS MODIFIER | 
eerroreanoness] ———SSCSC~*d 


| OPB CHECKSUM HIGH 
~ TIOPB CHECKSUM Low 


) 
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4.1.1 IOPB Byte 0 (Command) 


Bit ¥u r oti 


7 ERRS 
6 DONE 
5 CHEN 
4 SGM 
3-0 COMM 
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ERROR SUMMARY - ERRS is only valid if DONE is 
set. When set, a hard or soft error occurred 
during IOPB processing. When clear, the 752 
successfully completed the IOPB. 


NOTE 


Clear DONE and ERRS before 
executing an IOPB. 


DONE - When set, the IOPB is complete; if 
chained, software may remove the IOPB from the 
chain and reuse it. 


CHAIN ENABLE — When set, the Next IOPB Address 
Modifier and Next IOPB Address point to the 
next chained IOPB. When clear, this IOPB is 
not chained to another IOPB. The 752 always 
returns one IOPB at a time. 


SCATTER/GATHER MODE - When set, the IOPB is 
either a scatter (read) or a gather (write) 
transfer; a linked list describes the number 
of 16-bit words and to what address the 752 
transfers each section of the data. The link 
address modifier and the link address specify 
the link list location. When clear, this IOPB 
specifies the data transfer address; the data 
is transferred to/from contiguous memory. SGM 
is only valid for standard reads and writes. 
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4.1.2 IOPB Byte ] (Status Byte 1) 


After the 752 executes the IOPB, it sets DONE and posts a 
Completion Code in this byte. Completion Codes are only valid if 
DONE is set. A code of Ox indicates a successful completion; any 
other value indicates an error occurred (see Section 6). 


4.1.3 IOPB Byte 2 (Status Byte 2) 
IOPB Byte 2 is the Disk Status byte; it is only valid if DONE is 


set. Byte 2 (excluding bits 5 and 6) is read from the drive 
selected by this IOBPB. 


DUAL PORT BUSY | | | | 
SLIPPED REVOLUTION | | | 
COUNT SECTORS EXECUTED | | 
WRITE-PROTECT | 
DISK FAULT 

SEEK ERROR 

ON-CYLINDER 

DRIVE READY 


Bit u : , ioe) 


7 DPB DUAL PORT BUSY - Sets if the selected port in 
a dual ported drive is busy. 


6 SR SLIPPED REVOLUTION - Sets if the 752 is 
unable to DMA enough data to keep up with the 
disk; it waits until the sector comes around 
on the next revolution. 


5 CSE COUNT SECTORS EXECUTED - Sets if the current 
sector count is invalid and the 752 has to 
recount the sectors. 


4 WRPT WRITE-PROTECI - Sets if the selected drive is 
write—protected. 
3 DFLT DISK FAULT - Sets if a fault condition exists 


in the selected drive. 
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4.1.3 JOPB Byte 2 (Status Byte 2) (continued) 


Bit M : r oti 
2 SKER SEEK ERROR - Sets if the 752 selects a 
cylinder higher than the drive maximum, or a 


seek does not complete within 500 
milliseconds, 


1 ONCL ON-CYLINDER - The 752 sets ONCL when the 
| | selected drive is on-cylinder. 


0 DRDY DRIVE READY - The 752 sets DRDY when the last 
drive selected is ready. 


4.1.4 IOPB Byte 3 (Status Byte 3) 


IOPB Byte 3 is reserved. It reflects the 752's internal status. 


4.1.5 JOPB Byte 4 (Subfunction) 


IOPB Byte 4 is the Subfunction byte. Subfunction Codes follow a 
convention that indicates whether the code is generic to all VME 
controllers, generic to a group of controllers (i.e., 772, 712, 
751, 752, 7053, etc.), or specific to a particular controller. See 
Table 4-1. 


The 752 combines standard Command Codes with Subfunction Codes to 
define the required operation. Table 4-2 lists the 752 Command and 
Sub£unction Codes. 


subfunction Codes (Hex) Class 
00-1F | Generic to All 
20-3F Generic Tape 
40-5F 772-Specific 
60-7F Reserved 
80-9F Generic Disk 
AQ-AF 751-, 752-, and 7053-Specific 
BO-BF 712-Specific 


CO-FF Reserved 


Table 4-1. Subfunction Code Classes 
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4.1.5 IOPB Byte 4 (Subfunction) (continued) 


0 NOP 00 No Operation 
1 WRITE 00 Normal Write 
2 READ 00 Normal Read 
3 SEEK 00 Report Current Address 
01 Seek and Report Current 
Address 
02 Start Seek and Report 
Campletion Immediately 
4 DRIVE RESET 00 Drive Reset 
5 WRITE PARAMETERS 00 Write Controller Prmtrs. 
80 Write Drive Parameters 
81 Write Format Parameters 
6 READ PARAMETERS 00 Read Controller Prmtrs. 
80 Read Drive Parameters 
81 Read Format Parameters 
AON Read Drive Status Xtnd. 
7 EXTENDED WRITE 80 Write Track Headers 
81 Write Format 
82 Write Header, Header 
Verify, Data, and Data ECC 
AO Write Defect Map 
Al Write Defect Map Xtnd. 
8 EXTENDED READ 80 Read Track Headers 
81 Verify Data 
82 Read Header, Header 
Verify, Data, and Data ECC 
AO Read Defect Map 
Al Read Defect Map Extended 
9 DIAGNOSTICS 00. Self Test 
h-F RESERVED 


Table 4-2. Command/Subfunction Codes 
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4.1.6 IOPB Byte 5 (Unit) 


FIXED/REMOVABLE MEDIA ae | | 
RELEASE DUAL PORT eer, ee: 
PRIORITY SELECT eee eee | 

| 


Bit M : , ‘oti 


7 FIXD FIXED/REMOVABLE MEDIA - When set, the 752 is 
accessing the fixed media portion of a disk 
drive. When clear, the 752 is accessing the 
removable media portion of a drive. fMThis bit 
allows you to treat a fixed/removable drive as 
two separate disk drives. See Section 8.12. 


6 RDP RELEASE DUAL PORT - This bit is specifically 
used with dual ported disk drives. When set, 
the 752 releases the disk drive's port when it 
completes a command. When clear, the 752 does 
not release the disk drive's port when it 
completes a command. See Section 8.14. 


2 PSEL PRIORITY SELECI - When set, it forces the 
: Selection of a dual port drive. See Section 
8.14. 
4-3 RESERVED. 
2-0 UNIT UNIT NUMBER - This value specifies the Unit 


Number of the attached drive to which the 
transfer is directed (in the range of 0 to 7). 


NOTE 


Depending on the command, Bytes 6 through 13 have 
different definitions (see Sections 4.2 through 4.4). 
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4.1.7 IOPB Byte 6 (Interrupt Level) 


I716151}/4/3 12/110] 


LINK LIST LENGTH —“‘CSCSCSC*srYSCStsi‘ERNCNN$SC“UNNNNSSE""_s | | | 
INTERRUPT LEVEL 


Bit M e D e tj 


7-3 LLL LINK LIST LENGTH - Bits 3-7 specify the length, 
in elements, of a linked list for Scatter/ 
Gather commands. Each element refers to an 
8-byte block in the linked list. See Table 8-2. 


2-0 INTL INTERRUPT LEVEL - The 752 uses these bits as the 
VMEbus hardware interrupt level when = it 
completes the IOPB. The 752 will not interrupt 
if bits 0 through 2 are clear. 


4.1.8 IOPB Byte 7 (Interrupt Vector) 
IOPB Byte 7 determines the interrupt vector that the 752 uses upon 
command completion. This byte is not valid if the interrupt level 
is zero. 

4.1.9 IOPB Bytes 8 and 9 (Count) 
Byte 8 is Count High; Byte 9 is Count Low. These bytes specify the 
number of sectors to be transferred in a data transfer IOPB. ‘The 
format command uses this count to determine the number of tracks to 
format. 


4.1.10 JOPB Bytes A and B (Cylinder) 


Byte A is Cylinder High; Byte B is Cylinder Low. These bytes 
specify the starting cylinder address for a transfer. 
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IOPB Byte C specifies the starting head number for a transfer. 


4.1.12 JOPB Byte D (Sector) 


IOPB Byte D specifies the starting sector number for a transfer. 


4.1.13 JOPB Byte E (Data or Link Address Modifier) 


I716/1/5 74/13 1/2/71] 0] 


RESERVED. sisdr Cdl CURE 
DATA OR LINK ADDRESS MODIFIER... Cd] 


7-6 RESERVED. 
5-0 DATA OR LINK ADDRESS MODIFIER - If SGM is set, this field 
specifies the Link List Address Modifier; if SGM is clear, 


this field specifies the Data Address Modifier. The 752 
uses these modifiers to complete the address. 


4.1.14 JOPB Byte F (Next IOPB Address Modifier) 


[716/;/57;,4/13 1/2 ]11]0 | 


RESERVED i | | | | | | 
NEXT IOPB ADDRESS MODIFIER..._s—i“ wC*dC 


Bit Mi : c ‘oti 

7-6 | RESERVED. 

5-0 | NEXT IOPB ADDRESS MODIFIER ~ If CHEN is set, the 
Next IOPB Address Modifier, along with the Next 
IOPB Address, point to the next IOPB in the 


Chain. If CHEN is set, the 752 ignores this 
byte. 
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4.1.15 


4.1.16 


4.1.17 


4.1.18 


4.1.19 


IOPB Bytes 10 through 13 (DMA Data Address) 


IOPB Byte 10 is DMA Data Address High; Byte 13 is DMA Data Address 
Low. These bytes comprise the data or link list address pointers. 
The 752 uses these bytes with the data or link list address 
modifier to point to the data or linked list address. If SGM is 
set, this address points to the linked list; if SGM is clear, this 
address points to the data address. (The link list address must be 
on a 16-bit word boundary.) 


IOPB Bytes 14 through 17 (Next IOPB Address) 


IOPB Byte 14 is Next IOPB Address High; Byte 17 is Next IOPB 
Address Low. These bytes comprise the Next IOPB Address pointers. 
The 752 uses these bytes with the Next IOPB Address modifier to 
point to the next IOPB in the chain (if CHEN is set in Byte 0). 
(The Next IOPB address must be on a 16-bit word boundary.) 


IOPB Bytes 18 and 19 (IOPB Checksum) 


Byte 18 is IOPB Checksum High; Byte 19 is IOPB Checksum Low. ‘he 
752 calculates the checksum by adding the IOPB bytes and comparing 
the value against the value software calculated and put in these 
bytes. See Section 8.15. 


IOPB Bytes 1A and 1B (ECC Pattern Word) 


Byte 1A is ECC Pattern Word High; Byte 1B is ECC Pattern Word Low. 
These bytes are required for ECC Mode 0 and may be required for 
Mode 2 (see Section 6.4). 


IOPB Bytes 1C and 1D (ECC Offset Word) 
Byte 1C is ECC Offset Word High; Byte 1D is ECC Offset Word Low. 


These bytes are required for ECC Mode 0 and may be required for 
Mode 2 (see Section 6.4). 
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4.2 CONTROLLER PARAMETERS IOPB 


This IOPB sets and reads various controller parameters. The 752 — 
uses the standard IOPB, but redefines bits in Bytes 8 through E, 
and 10 through 13. | 


CONTROLLER PARAMETERS 


a eC Ce ee ee a 


oo LLeRRS] | [one] | [cHen] | [scr] 
0} 
op | lore] | [SR] 


INTERNAL STATUS 


SUBFUNCTION CODE 
ee ST 


INTERRUPT LEVEL 


ea err 
Led 
| 


A Aaa 


4.2.1 IOPB Byte 8 (Controller Parameters A) 


l716/5};,41/3 121110 
AUTO-UPDATE ss  Ct—iTC(‘<é‘i(ES &SECUTlCUCUElUCUWE CU 
TRANSFER MODE eee OO 
DISABLE ACFAIL = ee eee: ee 
IOPB CHECKSUM | 
ENABLE DMA TIMEOUT 
NON—PRIVILEGED REGISTER MODE 
RESERVED 
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4.2.1 IJOPB Byte 8 (Controller Parameters A) (continued) 


Bit : , “ot 


7 AUD 
6 TMOD 
5 DACF 
4 ICS 
3 EDT 


Rev. A. June 15, 1987 


AUTO-UPDATE - When set, the 752 updates the IOPB 
to the transfer's ending parameters; it updates 
the disk address, the sector count, and the data 
address after completing the transfer or 
detecting an error. When clear, the 752 only 
updates the IOPB if an error occurs. ‘The values 
are then set up so that host software can tell 
the 752 to continue (the values should point to 
the sector in error, the correct remaining 
sector count, and proper data address). 


TRANSFER MODE - When set, the 752 executes data 
transfers in Longword mode. When clear, it 
executes transfers in Word mode. ( IOPB 
transfers are alwayS in Word mode.) If a 
transfer starts on an improper address boundary, 
the 752 first transfers a byte and/or a word, as 
necessary to align boundaries, and continues the 
transfer in the selected mode. ‘The 752 may end 
the transfer with a byte and/or word. 


DISABLE ACFAIL -- When set, the 752 ignores the 
ACFAIL line on the VMEbus. 


IOPB CHECKSUM - When set, the 752 reads the 
IOPB, compares the checksum it generated during 
the read with the checksum the software driver 
appended to the IOPB. The 752 also updates the 
Checksum bytes in any IOPB if AUD is set. 
Clearing ICS disables this feature. See Section 
8.15. 


NOTE 
Since this feature adds at least 100 


microseconds to each transfer, it effects 
the 752's performance. 


ENABLE DMA TIMEOUT - When set, the 752 enables a 
DMA bus error timer. When clear, the 752 relies 
on an external VMEbus transfer timer. 
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4.2.1 JOPB Byte 8 (Controller Parameters A) (continued) 


Bit | Mnemonic 
2 NPRM 


1-0 


r ‘pio 


NON-PRIVILEGED REGISTER MODE — When set, the 752 
responds to address modifiers 2DH and 29H. When 
Clear, the 752 only responds to 2DH. (See the 
VMEbus Specification for more information on 
address modifiers. ) 


RESERVED. 


4.2.2 IOPB Byte 9 (Controller Parameters B) 


THROTILE DEAD TIME 
RESERVED 7 
RELEASE ON REQUES 
RESERVED 

DISABLE READ AHEAD 


Bit Mnemonic 


[71615 7/413121711/04 
I-} | - | Tt tT 4 
| | | 6 | 
| | ot 

| 

| 


, it; 


THROTILE DEAD TIME - TOT selects one of four 
minimum time periods that determines the time 
the 752 remains off the bus between throttle 
bursts (see Section 8.10). 


RESERVED. 


RELEASE ON REQUEST - When set, the 752 releases 
the bus at the request of other bus masters; 
otherwise, it continues with the next throttle 
burst. The 752 monitors the bus request lines 
and releases bus busy only if another bus 
request is pending. It completes its specified 
throttle burst before releasing the bus due toa 
pending request. When clear, the 752 releases 
the bus at the end of each throttle burst and 
rearbitrates if more data transfers are pending. 


See Section 8.16. 


7-6 TDT 
5 

4 ROR 
3-1 

0 DRA 
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RESERVED. 


DISABLE READ AHEAD - When set, the 752 disables 
its read ahead feature. When clear, the 752 
Satisfies all subsequent reads with data from 
the read ahead buffer (if possible). 
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4.2.3 LIOPB Byte A (Controller Parameters C) 


AUTOMATIC SEEK RETRY 


RESERVED 


RETRY BEFORE CORRECTION 
ERROR CORRECTION MODE 


Bit 
7 


6-5 


1-0 


I716'157/41312/11/10 4 


" , _ 


OVS 


ASR 


RBC 
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ENABLE OVERLAP SEEKS - When set, the 752 
initiates overlap seeks if more than one drive 
is present. When clear, the controller does not 
initiate Overlap Seek operations. 


RESERVED. 


AUTOMATIC SEEK RETRY - When set, the 752 resets 
the drive, seeks to the commanded cylinder and 
retries the transfer up to two times on any of 
the following errors: Seek, Header Error/ 
Cylinder, Header Error /Head, Drive Not 
On-cylinder, and Drive Faulted. 


RESERVED. 


RETRY BEFORE OORRECTION - When set, the 752 
retries the operation once on an ECC error 
without calculating the error syndrome. If an 
error occurs, on the second try, the 752 reverts 
to the specified error correction mode. 


ERROR CORRECTION MODE - There are three Error 
Correction modes. Mode 0 stops a transfer and 
provides the driver with the error's offset and 
pattern. The driver performs the actual 
correction. Mode 1 flags an error and continues 
the transfer. Mode 2 performs the correction in 
host memory, flags a soft error, and continues 
the transfer. 
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4.2.4 


4.2.5 


4.2.6 


4.2.7 


Rev. A. 


IOPB Byte B (Controller Parameters D) 


Bits 0 through 7 are the Throttle (THRO) bits. The throttle is the 
maximum number of transfers allowed each time the 752 becomes bus 
master. The throttle value determines the maximum DMA burst length 
for both data and IOPB DMA transfers. This byte allows a throttle 
setting from 1 to 256. 


Value Weight 
0 256 
1 1 
2 2 
3 3 
255 255 


Table 4-3. Throttle Values 


IOPB Byte C (EPROM Release Level) 


The 752 returns the EPROM release level on a Read Controller 
Parameters command. 


IOPB Byte E (Controller Type) 


IOPB Byte E is the Controller Type byte. Xylogics assigns each VME 
controller a unique controller type code. 


Controller Code {H) 
712 12 (ESDI Disk Controller) 
772 72 (Pertec Tape Controller) 
752 52 (SMD Controller) 


Table 4-4. Controller Type Codes 


IOPB Bytes 10 and 11 (EPROM Part Number) 


The 752 returns a portion of the EPROM part number on a Read 
Controller Parameters command. The 4 nibbles in these 2 bytes 
refer to the part number's last 4 digits. For example, if the part 
number is 180-002-173, Byte 10 holds 21H and Byte 1] holds 73H. 
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4.2.8 JOPB Byte 12 (EPROM Revision Level) 


This byte contains the revision level of the EPROM plugged into the 
board. | 


4.3 DRIVE PARAMETERS IOPB 


DRIVE PARAMETERS 


ae a a oe ee 


oo |_leRRS] | [OONE} | [CHEN | 

. 

oz | fore] | (sk) | [ese] | [wer] 
03 

a 

ro on a ss 


MAX CYLINDER HIGH 


Zz 
m 
x 
+ 
O 
U 
w 
> 
S, 
o 
7 
Mm 
WN 
Ww 
= 
O 
o 
a, 
m™m 
a 


OPB CHECKSUM HIGH 
OPB CHECKSUM LOW 
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4.3.1 IOPB Byte 6 (Drive Parameters) 


RESERVED 


a ne | 
450—COMPATIBLE MODE. —“‘C;ts*ts*s*s*sC*CSCSC~s*Y | | 
32-BIT ERROR CORRECTION CODE _..—“( wCC— | 

a eR 


RESERVED 
INTERRUPT LEVEL 


I71615/4/3 ]/2/11]/0 | 


Bit M ; , iotj 


7-6 

5 C450 
4 EC32 
3 

2-0 = INTL 
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RESERVED. 


450-COMPATIBLE MODE - When set, the 752 reads 
and writes 450-compatible format disks. ‘The 
format is compatible with disks having less than 
64-sectors per track. The 752 ignores the Drive 
Type field in the 450 header; it does not format 
in 450-Compatible mode. C450 does not override 
the format parameters set in the 752. EC32 must 
be set. 


NOTE 


Using C450, and EC32 in different modes 
on the two connecting disks reduces the 
disk subsysten's performance. ‘The 752 
must modify the disk sequencer code 
each time it switches drives. 


C450 only allows’ word _ boundary 
transfers since it swaps data bytes as 
DMAed to memory. 


32-BIT ECC — When set, the 752 uses a 32-bit ECC 
on the header and data. When clear, it uses a 
redundant header check, and a 48-bit data ECC. 
EC32 must be set when using the 450-compatible 
mode. (See the note below bit 5.) 


RESERVED. 


INTERRUPT LEVEL - See Section 4.1.7. 
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4.3.2 


4.3.3 


4.3.4 


4.3.5 


4.3.6 


4.3.7 


IOPB Byte 8 (Max Sector/Last Head) 


IOPB Byte 8 specifies the max sector value on the last head for use 
in cylinder sparing (this value is zero-based). Bytes ODH and 08H 
must be equal if cylinder sparing is not used. See Section 8.3.2. 


IOPB Byte 9 (Head Offset) 


IOPB Byte 9 specifies the drive's head offset value. Use zero for 
non-fixed/removable drives. Section 8.12 explains using the head 
offset to access fixed/removable drives. 


IOPB Bytes A and B (Max Cylinder) 


IOPB Byte A is Max Cylinder High; Byte B is Max Cylinder Low. 
These bytes specify the drive's max cylinder value. ‘This value is 
zero-based, i.e., the max cylinder on an 823 cylinder drive is 822. 


IOPB Byte C (Max Head) 


IOPB Byte C specifies the drive's max head value. This value is 
zero-based. 


IOPB Byte D (Max Sector) 


IOPB Byte D specifies the drive's max sector value. ‘This value is 
zero-based. See Section 8.3. 


IOPB Byte E (Sectors Per Track) 


IOPB Byte E returns the number of sectors per track (the 752 
determines this value by counting the sector pulses from the drive) 
on a Read Drive Parameters command. This is the actual number of 
sectors; it has not been modified to be zero-based. ‘This value 
does not include a runt sector (only one per track). 


The Format command uses this count to determine the number of 
sectors to format. Normal Read and Write commands use this count 
to limit the number of header compares before a Header Not Found 
error occurs. 
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4.4 FORMAT PARAMETERS IOPB 


FORMAT PARAMETERS 


c7yT«] s]«] s]?] 1] 


ss SUBFUNCTION CODE 
oe co ee UNIT 
LINTERLEAVE | INTERRUPT LEVEL | 
. INTERLEAVE oe INTERRUPT LEVEL 
INTERRUPT VECTOR 


OF NEXT IOPB ADDRESS MODIFIER | 


4.4.1 IOPB Byte 6 (Interleave) 


cman rien Guten GD Gere an Cane GTN GLY GOS GAG EID ISS GRD ARR SAAN SY LO ROY SITE CR A ED 


[716151413 1211101 


INTERLEAVE FACTOR |} | JI | | tod 
RESERVED | | | | 


INTERRUPT LEVEL 
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4.4.1 IOPB Byte 6 (Interleave) (continued) 


Bit M , oti 


7-4 INTF INTERLEAVE FACTOR - The 752 uses INTF during 
format operations. For 1:1 interleaving, the 
interleave factor is zero. The interleave 


factor for other ratios is (n+l):l, where n is 
the interleave factor. 


Interleave Factor Ratio 
Bits 7-4 


NF © 
9) WN 


ee 


rs MY) 
a 


Table 4-5. Interleave Factors 


3 RESERVED. 


2-0 INTL INTERRUPT LEVEL — See Section 4.1.7. 


4.4.2 IOPB Byte 8 (Field 1) 
Field 1 is the number of bytes from one byte after the index or 
sector pulse to when the 752 enables the Read Gate for headers; 
this value must be greater than or equal to one (Xylogics | 
recommends using one). See the note below Section 4.4.3. 

4.4.3 IOPB Byte 9 (Field 2) 
Field 2 is the number of bytes from when the 752 enables the Read 
Gate to when it starts looking for the Header Sync byte. Field 2 
must equal a non-zero value (Xylogics recommends OAH). 


NOTE 


The combined value of Fields 1 and 2 must not exceed 255. 
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4.4.4 IOPB Byte A (Field 3) 
Field 3 is the number of bytes from the sector pulse to the Header 
Sync byte; this value must be greater than or equal to the sum of 
Field 1 plus Field 2 (Xylogics recommends 1BH). 

4.4.5  JOPB Byte B (Field 4) 


Field 4 is the number of bytes between the Header ECC and the Data 
Sync byte; this value must be larger than ll (Xylogics recommends 


14H). 
NOTE 
Field 4 is actually four bits longer than this byte 


specifies. The 752 uses the extra four bits to test for a 
successful header compare and header verify. 


4.4.6 | JOPB Bytes C and D (Bytes Per Sector High/Low) 
Byte C specif ies Bytes Per Sector High; Byte D specifies Bytes Per 


Sector Low. The sector size (in bytes) must be larger than 254, 
even, and smaller than 3073. 


44.7 IOPB Byte 10 (Field 6) 


Field 6 is the number of bytes from enabling Read Gate to when the 
752 starts looking for data sync; this value must be larger than 
nine (Xylogics recommends OAH). 


4.4.8 JOPB Byte ll (Field 7) 


Field 7 is the number of bytes the Write Gate remains on after the 
Data ECC; this value must be greater than or equal to one (Xylogics 
recommends three). 
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5.0 


5.0.1 


5.0.2 


SECTION 5: COMMANDS 


GENERAL 


Each disk command begins a new page. An IOPB diagram follows each 
command description. The diagrams are highlighted to indicate 
which fields the 752 absolutely requires for command execution, 
which fields are optional for the command, and which fields it 
returns after execution. 


Each 752 IOPB is 30-bytes long. Reserving all 30 bytes for each 
IOPB maintains IOPB integrity. Generally, all commands use Bytes 0 
through 19H (Bytes 1AH through 1DH are reserved). 


Setting Up the Command 


Each IOPB diagram indicates the bytes or fields that must be set 
for each operation. Certain parameters are essential; others are 
optional. All commands require the Command, Unit, and Interrupt 
Level fields to contain valid information. ‘The Interrupt Vector 
field must be valid if the Interrupt Level is not zero. 


Completing the Command 


After the 752 completes the command, it updates IOPB Bytes 0 
through 3 with ERRS, DONE, a Completion Code, and an internal 
status. The 752 only updates the entire IOPB if Auto-update (AUD) 
is enabled, an error occurs, or if Read Parameters or Read Extended 
Status commands are executed. If AUD is set, and no errors occur, 
the 752 sets DONE, posts a Completion Code of zero in Byte 1, and 
disk drive status information in Byte 2; for any command that DMAs 
data to/from memory, the 752 updates the data and disk addresses to 
point to the last address plus one of the transfer. 


Status Action 
AUD Clear/No Error 752 updates Bytes 0-3 with ERRS, DONE, 
Occurs Completion Code, and internal status 


AUD Set/No Error Occurs 752 updates the entire IOPB 
AUD Clear/Error Occurs 752 updates the entire IOPB 
AUD Clear/A Read 752 updates the entire IOPB 
Parameters or Read 


Extended Status 
Command is Executed 


Table 5-1. Command Completion 
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5el NO OPERATION 


The No Operation (NOP) command is a diagnostic tool. The 752 reads 
the IOPB and marks it complete. 


NOP 


TESTIS Ziad G7 Ene 

ene 
WCOPEITTITSRITIMMCSEN weer | CorLT | III Ske |i llfoncu]| | RDv |] 
LE eee 
GZ Ve GE WijlMustt= — 

Zina 7 a a 
Wi 


Optionally Returned 
Required Value 


Required 
For Execution 
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Rev. 


WRITE DATA 


The 752, after reading and decoding the IOPB, positions the disk 
drive heads at the target cylinder; then it reads in the data from 
host memory (as per the IOPB) and writes the data contiguously to 
the specified disk address and subsequent sequential sectors. 


Write Data has two IOPB formats: Normal and Scatter/Gather. A 
Normal IOPB specifies one contiguous block of host memory to write 
to the disk. A Gather Write. IOPB specifies up to 32 different 
blocks of host memory to be placed in contiguous sectors on the 
disk (see Section 8.9). 


The 752 stores IOPBs in a command queue that holds up to ten full 


IOPBs. This queue allows the 752 to optimize the commands for 
overlap seeks. 


WRITE DATA 


Codd dh hhuhuh uhuhuathudiuhiuhie LAW 7 


jp re 


Ln 
UMMM 
CMIH@t oc 
MLE LLL 
Cua LL 
M/E 


MMM ELEY 
WM YY 
CL Lld lll ig ULL 


YUjffy Required ee] Optionally AAIUTANATAUAL Returned 
ila ForExecution (222222 2] Required Value | 
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READ DATA 


The 752, after reading and decoding the IOPB, positions the disk 
drive heads at the target cylinder, then reads the disk data 
indicated by the IOPB, and writes the data in host memory. 


Read Data has two IOPB formats: Normal and Scatter/Gather. A 
Normal IOPB specifies one contiguous block of host memory that is 
used to place the data from the disk. A Scatter Read IOPB 
specifies up to 32 different blocks of host memory where the disk 
data will be placed (see Section 8.9). 


The 752 stores IOPBs in a command queue that holds up to ten full 
IOPBs. This queue allows the 752 to optimize the commands for 
overlap seeks. 


READ DATA 


COMMAND CODE - 2 2 


MA COMMAND CODE = 2/7 


7 Por pacha (J Bina! 


(a 


Y, MY ee 
WII SO 
WYyvygyg = Yy7/y9/ yy, 
My "Ywpy—$fy 
me 


ee 
YU 
TLL LLL 


CLA For xecuion [ee oy IV eee 
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5.4 REPORT CURRENT ADDRESS 


The 752 selects the disk drive, reads the first good header field, 
and returns the address to the host via the IOPB; it updates the 
IOPB regardless of AUD's status. 


REPORT CURRENT ADDRESS 


7 | 6 | os tapos ft 
MT A AP, C. Munk ud nh unheautl hh nchenodhrudetenhe uate uf 


00 


ea 
NROPe ITS UIIIRCSEN IM RETIIPDELT) HSKeR |i once} [oRDy 


INIVUANVUUNTAAAAHU AVA eee HULU 
Witt 


01 
02 
03 


C nachrantaaattinsscndgunatenmthementiennntii-nanstlccaatlemnrslhemslhemuthervatirstnantiantametiora 


Miss /ASUBFUNCTION CODE = 00 WY) 


EE EE A ME EE A A A A A A A A 


____—CTEINKLISTLENGTH] —AINTERRUPT LEVEL 


04 
0S 
06 


DP ME MD ED ED 


wl GINTERRUPT VECTOR] 
- COUNT HIGH 

[COUNT LOW. 
“J COUNT LOW 


OA 


ree 
ee TTT TPevcwoer cow TTT TATA IL 
UTACUUANUUEEYEAUUUAUAUUUAU ACA xem ATAU EEA 
TTA WAIAUIVESec ror QTV ADV 
Po 
0 sir tore avoress roorer] 


OB 
oc 
OD 
OE 


OF 


DATA OR LINK ADDRESS HIGH 


10 


‘ 

12 

1 
14 | [NEXT JOPB ADDRESS HIGH | i 
is : 

16 

17 | 

18 | |JOPB CHECKSUM HIGH | 


ti Ret d 
Yl ee ition Seat TM ae 


W: 
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5.9 SEEK AND REPORT CURRENT ADDRESS 


The 752 issues a seek to the selected disk drive for the target 
cylinder. After the drive completes the seek, the 752 reads the 
first good header field it encounters and reports it to the host 
via the completed IOPB. The 752 updates the IOPB regardless of 
AUD's status. 


SEEK AND REPORT CURRENT ADDRESS | 


2 


sasasaueue ML ME ME A a LE 


To SST PEy 
oo [IERRS |I|[oone [| chen] [ser=0] V/A conmano Code = 3/7777 


Ad LF LE AE AT AE A ED EY AE A SE 


03 yyy yyy 
04 LOLOL OMLLLLML LM Mh pTLA 
TIES Yi GY 

* ee oD 


os COUNT LOW 


Ee 
SW MMWZZHtld dm ii fill 
- TTT ee, he 


HEAD WYYWwywy 


oc Arar aeh 


OO ee rn eee oeoer 

OE BEE HE Mane rrr 

OF He ae 

10 (DaTA OR LINK ADDRESS HIGH 


11 DATA OR LINK ADDRESS 


12 DATA OR LINK ADDRESS 
13 DATA OR LINK ADDRESS LOW 


ENN NIN INI ENGN ENING NINN SNES NINE INANE INENINANE OSEAN INL AES EYED LA PEPER TNA ePIC HEI EP OIE EP 
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ese setesasosesa cate se cece se set etesecece tes ecesorscesssenete tater esos otesesetenatets 
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syegesess 
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YI’: Required Tie] Optionally TAAL Returned 
YA For Execution [::s8:5:88858) Required Value 
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START SEEK AND REPORT COMPLETION IMMEDIATELY 


The 752 issues a seek to the selected disk drive for the target 
cylinder, and reports a completion to the host without waiting for 
the seek to complete. 


START SEEK AND REPORT 
COMPLETION IMMEDIATELY 


00 IE JERRS | {| OONE | 
01 


O02 bio oo TO oo er oo 


05 iia NIN 
04 Ln lane a SO A SE PP 


V/T onp 
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me et eee Seeeeeeeee 
ie SHSHUSHESSE TORIES ERS BEHEEEoEUoEtOGooDoed ——— Jo SESH ee ae ESE a SESE EEE 
‘ 

ON LLL LLLLLLiL hihi hihighaphaghaglelepapbagleapegbollaPuplapleplaplaplpoplagliplagta Yj 
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ae es BR 
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13 DATA OR LINK ADDRESS LOW 
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DRIVE RESET 


The 752 resets the disk drive. First it issues a fault clear, and 
then a recalibrate (return to zero). The IOPB is complete when the 
recalibrate completes or times out on drives that are ready. The 
752 does not wait for the recalibrate to complete on drives that 
are not ready. 


DRIVE RESET 


= a 


Yl [SUBEUNCTION COD = OLLI 


Lb ype 


AREY nn AY 


ME ES a 


[DATA OR LINK ADDRESS HIGH 
DATA OR LINK ADDRESS 


DATA OR LINK ADDRESS 
DATA OR LINK ADDRESS sual) 


-(1OPB CHECKSUM Low] 


WLLL, For txecution [ — TO) venue 
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5.8 WRITE CONTROLLER PARAMETERS 
This command initializes the 752 with its operational parameters. 


No default parameters are assumed. Section 4.2 defines how to 
change the parameters for individual applications. 


WRITE CONTROLLER PARAMETERS 


3 a 


te 
WA LOMMAND CODE = 5 VY 


VW. MMM 
ZEW 
= ae 


a RELEASE LEVEL 
CONTROLLER TYPE 


EPROM PART NUMBER HIGH 
EPROM PART NUMBER LOW 
EPROM REVISION LEVEL 


| [IOPB CHECKSUM HIGH 
"= IOPB CHECKSUM LOW |. 


Ylllln re ee 


N 
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5.9 WRITE DRIVE PARAMETERS 


This command specifies the disk drive's physical characteristics. 
The 752 assumes no default values. See Section 4.3. 


WRITE DRIVE PARAMETERS 


Chamntharticnthanatantin, jf 


| 2 
YEAS. 


LUE EAU 


LD LE A a a a 


VL 
See 


CL LLL Z 
aaa 
as LLL 


L, 
[i Ml 


\ 


WII. Required Te 


HH Required Value 
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This command specifies the disk drive's media format. 
752 uses a traditional RAM, 


WRITE FORMAT PARAMETERS 


WRITE FORMAT PARAMETERS 


3 2 


LE LE LD A a A a a a a a 


scm=0] W/Z COMMAND CODE = SV 


LLL LL 


— PER SECTOR HIGH 
BYTES PER SECTOR LOW 


UMMM 
LLL YL 


WLLL, For txecuvion Lt required” LLM vee 
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5.11 READ CONTROLLER PARAMETERS 


The 752 returns its current operational parameters to the host via 
the IOPB; it updates the IOPB regardless of AUD's status. See 
Section 4.2. 


READ CONTROLLER PARAMETERS 


Ie =a al UAHA AHA 
ea al = zal essa eal ese ic 


oe 
VET 
CaaS 


= 
PETES 


SE LE LES EP LE A OE SEP EG SP LP EP EP 


ee 
intimate iaasieneeceeennnannNTE 


Ue 
TMI Recerca wore cow INI 
TLINUIAINTIKEPeorREvston ceve™ TTIMMTIMMN MMT 
as 


“|10PB CHECKSUM HIGH E 
|OPB CHECKSUM LOW 


Optionally LIAUAUAACHIAI Returned 
Required Value 


LLL. a ecien 
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5.12 READ DRIVE PARAMETERS 
The 752 returns the values programmed for each drive's physical 
Characteristics to the host via the IOPB; it returns the specified 


drive's actual number of sectors per track in Byte OHH. ‘The 752 
updates the IOPB regardless of AUD's status. See Section 4.3. 


READ DRIVE PARAMETERS 


7 apes pts 


ED 
——— 


é BER ERE risttis . Ret a 
Wt:- Peee aiteh oe mos TAUAAANANT ae 
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5.13 READ FORMAT PARAMETERS 


ters to the 
The 752 returns the selected disk drive's format parame 
host via the IOPB; it updates the IOPB regardless of AUD's status. 


See Section 4.4. 


READ FORMAT PARAMETERS 


a fe 2 


eausawosane OP A A A ES ES A 


| [scn=0] WA comMaND CODE = 6 W/W 


)p 
eee 
Hore WSR INTITCSE NT WERT [IU LDFLT II TSKER HI TONCL} HH ORDY |] 


Ls ee ee NNN 
Witt: cums 7/740 
WANN en ZA rea 


EL ee eee ee 


INTERRUPT VECTOR 


000-000-0000. 0009-00 OOO 


MM TM 
UURTIUANURTACUE ATAU Uae TUT 
UTICA eee 
UURTETAUATTAETUATAU ETAT 
UIT ceca NNN 
WUUITUTITTUUUTAA UU ato ana TTT 
ee Lae 


00 
01 
02 


03 
04 
05 


06 


07 
08 
09 
OA 
0B 
oc 
OD 
OE 


OF 


Pp Se 

LEE 
TET TCE reco. 2 TATA 
re 


bred eetetet . 
eos fesessse 


: NEXT IOPD ADDRDee aT Pore eremenenrteerrnenenerrers 


6000000000000000000000000000000004 


;: 


[lOPBCHECKSUMLOW] 
% R j 
VLE For Execution 


10 
V1 
12 
13 
14 


17 


18 
19 


settee 


Optionally LUQUUNAUUAAUAT Returned 
Required Value 
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READ DRIVE STATUS EXTENDED 


The 752 reads the SMD drive interface's extended status. It 
returns the drive's status in IOPB Bytes 8 through A regardless of 
AUD's status (see Table 5-2). The drive-specific bytes follow the 
same bit alignment as the standard Status byte. 


Byte Tag 4 Tag5 Bit:2 6&6 3 4 3 2 lL, 9Q 


02 0 0 SECT INDX ADM WRPT DFLT SKER ONCL DRDY 
08 1 0 * k k Ok * * x * 
09 0 1 % * k Ok x * * * 
OA 1 l * * zk * * * * 


* Drive-specific 


Table 5-2. Extended Drive Status 


READ DRIVE STATUS EXTENDED 


Lge 


LINK LIST LENGTH 


5 ; R fe) wr} Optionall Returned 
Wt Fee ae ieh Al stan TAAL Velue 
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WRITE TRACK HEADERS 


The host writes the sector header fields on a track (only one track 
per IOPB). The 752 takes the data for the header fields from host 
memory: four bytes per header; one header for each sector on the 
track. (The data fields are not preserved.) It places the data on 
the track starting from index. Section 8.3 defines the data format 
in each header. 


WRITE TRACK HEADERS 


3 


Git EA 


es < 


“COUNT HIGH] 
COUNT LOW 


Ctcounriw SECC 
WII ES OLIIM“{“ASJ“Xn 
ZZ ES OUMMMLLIUIII” 
» LLL OL 
I ae 


a 
WHYIIII!ZX_ SOY 
LLB OR LINK ADDRESS WY) 
CM ee ere 


iw ae vent ee 7 xtra TAUNAIANAAIAAI tiles 
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5.16 WRITE FORMAT 


The 752 formats the Seige: writing the header of all sectors with 
the appropriate sector ID. ‘The data field contains zeros and a 
valid ECC. The Count bytes in this command refer to the number of 
tracks to be formatted. See Section 8.2. 


WRITE FORMAT 


a a a | 


[| 
YEA. 


Le 
MMI 
CMMHT04- HMMM 
WH = UI 
MMMM LL 
ee eo 


y, —_ 3 : . ' seen RRR Gptionaity Returned 
YFHH ie veo ee Required HUAN Value 
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5.17 


WRITE HEADER, HEADER VERIFY, DATA, AND DATA ECC 


The 752 writes a sector header , header verify, data, and data ECC. 
There are always four bytes in the header, but: the other fields 
vary according to the initial 752 set-up. 
head or cylinder boundaries while executing this command. 


The host must calculate the ECC in all ECC fields Since the 
controller does not calculate any ECC fields for this command. See 
Section 8.ll. | 


WRITE HEADER, HEADER VERIFY, 
DATA, AND DATA ECC 
= 


VY, 
GOAT ee 


LL 
MLE" 
a WW MMUUZJ]—”00000 
WEEE: AHEAD ~UUUY“Yyyyywyywv 
WHMCIHCHHTEYVTI|l SEY XI IT-/|! ZZ,” 
-- = =p ®VW/, 


MMMM Bah oe Ie ADDRES NEN 
WM JY I 
CH cee 

= MMMM 


Wf) eeauired oo 7 cor TU) ee 
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WRITE DEFECT MAP 


Write Defect Map is a useful maintenance command for debugging 
software. The 752 uses data from host memory and writes a 
manufacturer's defect map to the disk. See Section 8.1. 


WRITE DEFECT MAP 


3 2 
LD LT a a OE a ey 


Vip pssZACOMMAND CODE = 7 YYW 


WE GUI 
CMM. WLLL. 


CLL 


N/E AMM 


CMA WY 
Go 
ee eee 


V Required 7 * = 0 ti 1 Returned 
Wtth--»> Porevecunish oe pcgulced:: (TT ie 
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debugging software. 


WRITE DEFECT MAP EXTENDED 


Write Defect Map Extended is a useful maintenance command for 
The 752 uses data from host memory and writes 
a manufacturer's defect map to the alternate location on the track. 
This offsets the defect map from index, avoiding media defects. 


WRITE DEFECT MAP EXTENDED 


aren raathoclipagt 


CLA LLL 


a 


es en OI 
CI yy 


Vp, For Execution [ccc Sesggey Required Value 
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5.20 READ TRACK HEADERS 


The host reads the sector header fields on a track. The 752 places 
the data from the header fields in host memory: four bytes per 
header; one header for each sector on the track. Section 8.3 
defines the data format in each header. 


READ TRACK HEADERS 


3 2 


“TEOUNT HIGH) 
COUNT LOW 


CHM: LH 


Beau 


eZ, 


PO HH ae HH SESE 
es 
WII eee MLL: 
CO 

Fe 


Ht, Required Tite] Optionally ” Tm Returned 
YA ForExecution [2:22 388 ee Required Value 


Rev. A. June 15, 1987 63 


XYLOGICS 752 Disk Controller User's Manual 


5.21 


The 752 verifies the data on the disk: 
host and the disk simultaneously, and compares them on a bit-by-bit 
The granularity of the mismatch reporting is one sector. 
The ending data address does not indicate where a mismatch error 
occurred. 


basis. 


VERIFY DATA 


VERIFY DATA 


? TEE 3 


a 
SS 


LOT 
WHY) 
QU EE NYY 

BZ 


, _ BERR REE: | j Ret d 
WLLL, Fortrecution || reauired” UM verse 
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5.22 READ HEADER, HEADER VERIFY, DATA, AND DATA ECC 


The 752 reads a sector header , header verify, data, and data ECC. 
There are always four bytes in the header, but the other fields 
vary according to the initial 752 set-up. The 752 reads the 
physical sectors regardless of the interleave factor; it does not 
cross head or cylinder boundaries. See Section 8.ll. 


READ HEADER, HEADER VERIFY, 
DATA, AND DATA ECC 
3 


Witt, 
WE 
V/ 


CMLL: yyy 
OLE LN 
ae WL: nee Sotceccnenf ipo 
mee WZ 


ALLENS 
eee Z, 
MME ence 


THE Required Value 


| tht; 7 fis ee 


\ 
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5223 READ DEFECT MAP 


The 752 reads the manufacturer's defect map and returns the data to 
memory in the correct bit order. See Section 8.1. 


READ DEFECT MAP 


_ 7 3 AE Ee OS | 
oo HERRS [pone || chen) [Sert=0] V/A COMMAND CODE = 817 
a Ha eee 
0 TT SE ell aca ema es 
03 i mx NI 
6 {CLiiZ Ya Se YY YM 
05 Zn at GaZ SS 
a 
09 
"\ W§edchd thay, 
9. Mttttd-gqq> AG SG lt 
Os VWMMMMXZ=M/MHMW@Ua—x=EZ_M@_ | dt 
oD SN Eee [SECTOR] 
OF —— fi SS See en 
: MM EEE UU 
; My GM 
LLAMAS SLL 


iff Required Tice] Optionally SANAUAAUAAUEAT Returned 
YA For Execution —222 254! Required eee 
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5.24 READ DEFECT MAP EXTENDED 
The 752 bypasses any media defects and reads the manufacturer's 


defect map from the alternate location on the track. See Section 
8.1. 


READ DEFECT MAP EXTENDED 


2 


LE EF a EP a a La ee Wz 


LUE NOM 


LF LD OT A a A A 


ne 
a. 


COUNT HIGH 
COUNT LOW 


A eT 
CMM LEX 
UMMM 


ee 
PO HEHE SHEEHY SEHR E HEHE 


LLL: es O 
Wi ane MM 
LAE MMM 


\ 


t tify Required seers 
ZA For execution [2:82 


cJreaires” QUQ0M veiw." 
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5.25 DIAGNOSTICS 
The 752 executes the on-board self test diagnostics. Do not chain 


this IOPB to another IOPB. It cannot be used in conjunction with 
other IOPBs in the command queue. 


DIAGNOSTICS 


TT MT EP 


2 po 
VJs /A COMMAND CODE = 9 WWW 


eee = YZ 
a 
___rerioreanoress] —SCSC~“~*~*d 


NEXT IOPB ADDRESS 
LUNEXT lOPB ADDRESS au 
31 10PB CHECKSUM HIGH |=: 


Tee] Optionally AUAUTUUAUANUAI Returned 
HEE Required Value 


Uff}f}fH}3 Required aaananae 
YA For€xecution —e2228 
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6.1 


6.1.1 
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GENERAL 


The 752 Error Summary (ERRS) bit, Fatal Error (FERR) bit, and 
Completion Code represent the controller's status after executing a 
command. FERR indicates the transfer failed and the 752 requires a 
Controller Reset before continuing. ERRS only affects the specific 
IOPB and may be tested in lieu of checking the Completion Code; the 
752 does not require a Controller Reset before continuing. ‘the 
Completion Code informs software that the 752 successfully 
completed a command, failed to complete a command, or encountered 
and corrected a problem with one of several internal recovery 
procedures. 


THE COMPLETION CODE 


The 752 posts a Campletion Code in IOPB Byte 1 (Status Byte 1); a 
Completion Code is only valid if DONE is set. Table 6-2 lists the 
Completion Codes (all codes not listed in this table are reserved). 
The following subsections describe these codes, along with any 
required corrective action. 


Completion Code Convention 


Completion Codes follow a convention that recommends the action 
required by either the software driver or manual intervention. The 
byte's upper nibble is the recovery code, and the lower nibble is 
the actual error code (see Table 6-1). 


Recovery Procedure 


No Action / Status Only 
Non-retryable Programming Error 
Successfully Recovered Soft Error 
Hard Error / Retry 

Hard Error / Reset and Retry 
Fatal Hardware Error 
Miscellaneous Error 

Requires Manual Intervention 


WO On & WE © 


Table 6-1. Recovery Codes 
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6.1.1 Completion Code Convention (continued) 


Action 
No Action / Status Only 


Non-retryable Programming 
Errors 


Successfully Recovered 
Soft Errors 


Hard Errors/Retry 


Hard Errors ~— Reset/Retry 


Fatal Hardware Errors 


Miscellaneous Errors 


00 


80 


Requires Manual Intervention 90 


Table 6-2. 
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Code (Hex) § Description 


Successful Completion 


Illegal Cylinder Address 
Illegal Head Address 

Illegal Sector Address 

Count Zero 

Unimplemented Command 

Illegal Field Lengths 1-7 
Illegal Scatter/Gather Length 
Not Enough Sectors/Track 
Next IOPB Alignment Error 
Scatter/Gather Addr. Alignment 
Scatter/Gather With Auto ECC 


Soft ECC Corrected 

ECC Ignored 

Auto Seek Retry Recovered 
Soft Retry Recovered 


Hard Data ECC 
Header Not Found 
Drive Not Ready 
Operation Timeout 
VMEDMA Timeout 

Disk Sequencer Error 
FIFO Parity Error 
Dual Port Busy Timeout 
Header ECC Error 
Read Verify 

Fatal VMEDMA Error 
VMEbus Error 


Drive Faulted 

Header Error/Cylinder 
Header Error/Head 
Drive Not On-cylinder 
Seek Error 


Illegal Sector Size 
Firmware Failure 


Soft ECC 


Write-protect Error 


Summary of Completion Codes 
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6.1.2 Completion Code Descriptions 
6.1.2.1 No Action / Status Only 


Typically, the following Completion Code requires no action; the 
752 returns the code for status only. 


Code(H) Description 


00 SUCCESSFUL COMPLETION — Not an error; indicates the IOPB 
is complete. 


6.1.2.2 Non-retryable Programming Errors 


This group of errors is usually encountered while debugging 
drivers; they should not occur in a normal operating system 
environment. 


Code(H) Description 


10 ILLEGAL CYLINDER ADDRESS — Host software specified a 
cylinder address greater than the maximum cylinder number 
specified in the last Set Drive Parameters command for 
this drive. 


ll ILLEGAL HEAD ADDRESS —- Host software specified a head 
address greater than the maximum head address specified 
in the last Set Drive Parameters command for this drive. 


12 ILLEGAL SECTOR ADDRESS -- Host software specified a 
sector address greater than the maximum sector number 
Specified in the last Set Drive Parameters command for 
this drive. 


13 | COUNT ZERO — Host software issued the 752 an IOPB that 
required a count, but the count was zero. Read, Write, 
and Format commands require a valid count. 


14 UNIMPLEMENTED COMMAND -—- ‘This error occurs on all 
reserved commands. 

15 ILLEGAL FIELD LENGTH 1 — See Section 8.2.2.1. 

16 ILLEGAL FIELD LENGTH 2 -—— See Section 8.2.2.2. 

17 ILLEGAL FIELD LENGTH 3 — See Section 8.2.2.3. 
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6.1.2.2 Non-retryable Programming Errors (continued) 


Code(H) Description 


18 
1A 
1B 


1c 


1D 


1E 


IF 


20 


ILLEGAL FIELD LENGTH 4 — See Section 8.2.2.4. 
ILLEGAL FIELD LENGTH 6 —- See Section 8.2.2.5. 
ILLEGAL FIELD LENGTH 7 — See Section 8.2.2.6. 


ILLEGAL SCATTER/GATHER LENGTH -— ‘The linked list 
specified a number of words to transfer that does not 
agree with the amount of data contained in the requested 
number of sectors for transfer. 


NOT ENOUGH SECTORS PER TRACK — The format routine was 
unable to format since too few sectors were actually 
available on the track. 3 


NEXT IOPB ALIGNMENT ERROR -- ‘The Next IOPB Address did 
not start on a 16-bit boundary; the 752 does not execute 
the NIOPB. 


SCATTER/GATHER ADDRESS ALIGNMENT ERROR — A 
Scatter/Gather address did not start on a 16-bit 
boundary. 


SCATTER/GATHER WITH AUTO ECC ERROR — A Scatter/Gather 
operation ended with a soft ECC error; due to Scatter/ 
Gather boundaries, the 752 did not autamatically correct 
the error, but reverted to ECC Mode 0. 


6.1.2.3 Successfully Recovered Soft Errors 


This group of errors is for status only. If some errors recur 


often, 


the operating system should try to map out the sectors 


involved. Allowing these errors to recur degrades performance. 


Code(H) Description 


30 


31 


SOFT ECC CORRECTED — The 752 detected and corrected one 
or more ECC errors, during a disk read, in ECC Mode 2. 


ECC ERROR IGNORED — The 752 detected, but ignored, an 
ECC error (during a Read command, in ECC Mode 1) and 
continued the transfer. 
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6.1.2.3 Successfully Recovered Soft Errors (continued) 


Code(H) Description 


32 


33 


AUTO SEEK RETRY RECOVERED -—- ‘The 752 completed the 
transfer successfully but, during the transfer, it 
recovered from an error by resetting the drive. 


SOFT RETRY RECOVERED — A retry was successful: either 
by setting RBC or issuing a zero latency read. 


6.1.2.4 Hard Errors/Retry 


These errors indicate the transfer failed; retry the operation. If 
several retries fail, manual intervention is required or the 
operating system may crash. 


Code(H) iotj 


40 


4] 


42 


43 


44 


45 


HARD DATA ECC ERROR -- The 752 detected a hard data ECC 
error in the data field during a Read command. Retry the 
previous Read operation. 


HEADER NOT FOUND -—- The 752 cannot find the requested 
sector. The controller searches for one disk revolution 
plus one sector to locate the header. See Section 9.3.2. 


DRIVE NOT READY — The selected drive is not ready, but 
not faulted; issue a Drive Reset. Causes include: 


Drive not up-to-speed. 

Drive hardware error. 

Bad or improperly connected cable(s). 

No drive of the specified unit number is connected 
to the 752. 


O000 


OPERATION TIMEOUT — The 752 did not complete the IOPB 
within a two second timeout period. 


VMEDMA TIMEOUT -—- The DMA controller did not complete 
within its allotted time limit. One reason could be that 
memory did not respond in time. 


DISK SEQUENCER ERROR -- The disk sequencer did not 
complete its task within the allotted time limit. 
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6.1.2.4 Hard Errors/Retry (continued) 


Code(H) Description 
45 DISK SEQUENCER ERROR (continued) -- The 752 cannot send 


or receive the appropriate signals from the selected 
drive. Causes include: 


Oo Improper or defective cabling. 
o Unformatted drive. 


46 FIFO PARITY ERROR -—— ‘The transfer failed; the 752 
detected a FIFO buffer parity error. , 


‘47 DUAL PORT BUSY — The 752 timed out while waiting for the 
port on a dual ported drive. The timeout is two seconds. 


48 HEADER ECC ERROR — The 752 found a header match, but the 
Header ECC did not compare. 


49 READ VERIFY ERROR -- The data read from the disk did not 
match the data read from memory. 


4A FATAL VMEDMA ERROR -—- The VMEDMA stopped for no apparent 
reason. The count nor the address overflowed, and there 
was no bus error. 


AB VMEBUS ERROR -- The VME BERR* Signal was asserted while 
the 752 was bus master (see the VMEbus Specification). 


6.1.2.5 Hard Errors - Reset/Retry 


This group ot errors indicate the transfer failed. Software should 
issue a Drive Reset command to the drive in use before retrying the 
operation. 


Code(H) Description 


60 DRIVE FAULTED — The selected drive is faulted. Issue a 
Drive Reset. If the fault persists, you must intervene. 


61 HEADER ERROR/CYLINDER -—- The cylinder address did not 
match during a sector search. Check the cylinder address 
and retry the operation. 


62 HEADER ERROR/HEAD -- The head address did not match 
during a sector search. 
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6.1.2.5 Hard Errors — Reset/Retry (continued) 


Code(H) Description 

63 DRIVE NOT ON-CYLINDER -—— At some point during the 
transfer, the 752 expected the drive to be on-cylinder, 
and it was not. 


64 SEEK ERROR -—- The disk drive reported a seek error. 


6.1.2.6 Fatal Hardware Errors 


These errors indicate the hardware failed. Manual intervention or 
a Controller Reset may be the only recovery approach. 


Code(H) Description 


70 ILLEGAL SECTOR SIZE — The disk drive's sector size is 
not large enough to hold the header, data, and specified 
field lengths. Verify your drive's sector switch set- 
tings against the 752's minimum sector size requirements. 


71 FIRMWARE FAILURE -—- Flag settings or counter values are 


inconsistent with the firmware routines being executed. 
Document the conditions and call Xylogics. 


6.1.2.7 Miscellaneous Errors 


Code(H) Description 

80 SOFT ECC ERROR -—— The 752 detected a correctable error in 
the data field of the current sector, during a Read 
operation, in ECC Mode 0. Software must perform the 
final correction. See Section 6.3. 


6.1.2.8 Requires Manual Intervention 


The write-protect error requires you to manually remove the 


write—protection. 
Code(H) Description 
90 WRITE-PROTECI ERROR -—- A command that writes to the disk 


(e.g., Write, Format, Write Track Headers) is issued, but 
the drive is write-protected. 
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6.2 


6.3 


6.3.1 


SOFT ERROR COMPLETION CODES 


The 752 updates the IOPB with the last error it encounters; it may 
overwrite previous soft errors with a new soft error status or a 
hard error status. 


ERROR CORRECTION CODE 


Most ECC algorithms require retrying the operation at least once 
before attempting the correction. When RBC is set, the 752 
automatically retries the operation once before applying the 
correction algorithm. 


Error Correction Code - Mode 0 


When using Mode 0, the following procedure corrects a soft ECC 
error. The 752 provides a pattern and offset for the correction 
process. 


l. Reserve 32 bits of storage for the shifted ECC pattern, and 
initialize them to zero. ‘Take the ECC Pattern word from the 
IOPB and put it in the lowest 16 bits of the reserved space. 


2. Get the offset from the IOPB and decrement by one. ‘This makes 
the count zero-based instead of one-based. 


3. Use the three low order bits of the offset as a count to shift 
the pattern the number of count bits left. 


4. Divide the bit address by eight (by performing three logical 
shifts to the right). The result is the word offset into the 
bad sector. Adding this offset to the starting memory address 
of the sector in error creates a pointer to the first word to 
be corrected. 


5. Exclusive-OR the three Memory bytes at the pointer and the two 
Pattern words generated in step l. 


Rev. A. June 15, 1987 76 


XYLOGICS 752 Disk Controller User's Manual 


6.3.2 


6.3.3 


6.4 


Error Correction Code - Mode 1 


The 752 does not correct any detected errors in Mode l. After 
completing the operation, it posts a Completion Code indicating 
that at least one ECC error occurred during the transfer. 


Exxror Correction Code - Mode 2 


The 752 autamatically corrects a soft ECC error in this mode. The 
752 determines the pattern and offset, completes the DMA, and goes 
to host memory to fetch the data in error; it corrects the data, 
and returns it to memory. 


FATAL ERROR CODES 


If a fatal error occurs, the 752 sets FERR in the Status Register 
and posts the error code in the Fatal Error Register. (The 
following error codes appear only in the Fatal Error Register.) 
The only way to clear a fatal error is by issuing a Controller 
Reset (CRST). 


Code(H) Description 
EO RESERVED. 


Fl IRAM SELF TEST FAILURE — The 752 tests the IRAM with an 
incrementing data pattern then tests it with a 
decrementing pattern. An error indicates a bad IRAM. 


E2 RESERVED. 


E3 MAINTENANCE TEST 3 FAILURE —- The 752 tests the Writable 
Control Store in the DSKCEL with an incrementing data 
pattern then tests it with a decrementing pattern. An 
error indicates a bad DSKCEL. 


E4 MAINTENANCE TEST 4 FAILURE — The 752 shifts a pattern 
ot 0's and 1's through the Header Shift Register (HSR). 
An error indicates a bad HSR. 


E5 MAINTENANCE TEST 5 FAILURE -- The 752 writes, and then 
reads, the VMEDMA Registers. An error indicates a bad 
VMEDMA. 

E6 MAINTENANCE TEST 6 FAILURE -- There is a problem with 


the REGCEL chip. 
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6.4 FATAL ERROR CODES (continued) 


Code(H) Description 


E/7 


E8 


FO 


Fl 


F2 


F3 


F5 


F6 


MAINTENANCE TEST 7 FAILURE -- The FIFO parity circuit 
failed its diagnostic. 


MAINTENANCE TEST 8 FAILURE -- The 752 fills the Disk 
FIFO with sequential data and then reads it. An error 
indicates a problem with the DSKCEL or FIFO. 


IOPB CHECKSUM MISCOMPARE -- The generated checksum did 
not match the appended checksum. ‘This error can only 
occur while IOPB checksum feature is active. ICS is 
controlled via controller parameters. See Section 8.1l. 


IOPB DMA FATAL -- The 752 did not complete the DMA 
within the prescribed timeout period. The memory could 
be defective or not present; the 752 may not have been 
able to become bus master. 


IOPB ADDRESS ALIGNMENT ERROR — The IOPB address did not 
start on a 16-bit boundary. Change the address of the 
IOPB and retry. 


FIRMWARE ERROR -- Flag settings or counter values are 
inconsistent with the firmware routines being executed; 
the IOPB cannot DMA the appropriate error status. The 
752's state 1s indeterminate; you must issue a 
Controller Reset. 


ILLEGAL MAINTENANCE MODE TEST NUMBER — The command is 
invalid, or the Maintenance mode jumper is not in. 


ACFAIL ASSERTED — The VMEbus signal ACFAIL is asserted, 
causing the 752 to stop. Correct the problem asserting 
ACFAIL and then reset the 752. 
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SECTION 7: A TUTORIAL IN PROGRAMMING THE 752 


GENERAL 


This section describes programming the 752 for basic use. This 
tutorial programming procedure begins with a single NOP IOPB and 
progresses to normal Read and Write commands. Each section builds 
on the previous section's information. (In the Sent/Returned 
portion of each sample IOPB, the x represents an indeterminate 
value that depends on the external conditions. ) 


NO OPERATION (NOP) 


The NOP command allows you to become familiar with the 752 
programming interface. 


NOP 
SENT | RETURNED 

00 00 40 
se 00 00 
os 00 Ox 
03 00 xx 
a 00 00 
ae 00 00 

00 00 


00 00 


0 | 0» 
: 0 | a 


a 00 00 
= 00 00 
OF & aa e 00 00 
< 00 00 
i 00 00 
"3 00 00 
14 PB ADDRESS HIGH | } 00 00 
is b _INEXT 10P8 appREss] __] 0 | 00 
is E [NEXT 10PB ADDRESS] ee 
We = i 00 
18 | 00 00 


Value 


LLL, For txecution [E 


Figure I-1 « Sample NOP IOPB 
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Takel Allocating Memory for an IOPB 


First, allocate space in host memory to store the IOPB. fThis 
allocation is a function of the operating system or the program 
that is currently executing. Next, set up the IOPB to execute a 
Simple NOP command. 


7ele2 Point the 752 to the IOPB 


The IOPB is now in host memory. Point the 752 to the IOPB by 
loading the IOPB address and address modifier into the appropriate 
752 registers. The 752 looks for the IOPB at the physical address 
to which the registers point. 


NOTE 


Make sure the address compensates for any memory mapping 
that may be done between virtual and physical addressing in 
your system. 


7.1.3 Starting the Operation 


The 752 now points to the IOPB in host memory. Setting AIO in the 
CSR directs the 752 to process the IOPB. 


7.1.4 252 Operation 
At this point, the 752 performs the following functions: 


1. Clears AIOP and sets BUSY. 
2. Reads the IOPB from host memory. 
3. Decodes the command. 
4. Performs the operation (NOP). 
5. Sets the DOWE bit. | 

6. Updates the IOPB. 

7. Puts the completed IOPB's address into the registers. 
9. Clears BUSY. 
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7.1.5 Command Completion 
Sottware has been polling RIO (since interrupts are not enabled 
[Interrupt Level = 0]). The 752 sets RIO when it is done. 
Software should get the completed IOPB's address from _ the 
registers, and then clear RIO. This completes the NOP command. 


NOTE 


Do not poll the DONE bit in the IOPB. ‘The 752 sets DONE 
While the rest of the IOPB is still updating. 
7.1.6 $Returned Values 
DONE is set in the returned IOPB. Status Byte 2 reflects the 
status of Disk Drive 0. Status Byte 3 reflects the 752's internal 
status. 
NOTE 
Status Byte 3 is proprietary to Xylogics and may 
change definition without notice. 
762 READ CONTROLLER PARAMETERS 
Next, implement a Read Parameters command with a Controller 


Parameters subfunction (see Section 4.2). This command returns 
several controller parameters in the IOPB. See Figure 7-2. 


7.2.1 Execute the JOPB 
Set up the IOPB in host memory; point the 752 to the IOPB. Set AIO 
and the 752 executes the IOPB in Figure 7-2. 


7.262 152 Operation 


The controller operation changes slightly from the example in 
Section 7.1.4: 


The 752 performs the Read Controller Parameters operation instead 
of the NOP. The controller gets the parameters from its internal 
store, and puts them in the proper IOPB locations. The 752 fully 
updates the IOPB, including the returned values. 
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7.23 


Specific bytes have known values. 
contains a 53H; the EPROM Part Number bytes contain 21H and 73H. 
See Section 4.2 for more information. 


The Returned IOPB 


The values in the returned IOPB describe the last setting of the 
software-programmable parameters. 
for your application. 
the parameters back to the 752. 


READ CONTROLLER PARAMETERS 


aS 2 
LALOPMAND CODE = © 1// 


I feRes UI Lrg cORmiand CODE = 8V///7) 
0 CETTE compuerion coo 


os TNT eee starus TM 
06 VL ZAANTERRUPT LEVEL 


BERRA Setsistsisesssesesesses : Sinstitessnesines PARRA ROO RAE RR AR ROTH parsers DInspesrisstiness 
sligsresesesssssese sesscegssisegese PEP OTSSPSS TSC ILIS ISS OTS Peet reeeres esas tte ee reey stieesicts Spigerspenigtgsss 


etetee. 
Pestesteset eres 


ssapesse See sen are eggs FFP SSCSHSESCHTOBE) BARES OUAHSSERREI ESET SSeeosccus ages DPEeeeasesanen 


eovcereeoous an een o 0 2 | ees 6068686086600 0 eee £88 § eee 2 saee 


sceconce RUC BEES OCS) Ee CUSSsececeend SU) Eee oi sonsseses 
sesesaes naanence sesesnase easesessasne 


rm UUVAUNNUAAAATIU AAV AHA enema THU 
WUT REPROM REVISION LeveL 


a] Required Value 


Witt; eee tion ae 


Figure 7-2. Sample Read Controller Parameters IOPB 
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06 


00 
00 
00 
00 
00 
00 
00 
00 
00 
04 
00 
00 
00 
00 
00 
00 
00 
00 
00 
00 
00 
00 
00 
00 
00 


Determine if each value works 
After making any necessary changes, write 


The Controller Type byte 


RETURNED 
46 


00 
XX 
XX 
00 
00 
00 
00 
XX 
XX 
XX 
XX 
00 
00 
52 
00 
2 ' 
73 
XX 
XX 
00 
00 
00 
00 
00 
00 
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WRITE CONTROLLER PARAMETERS 


Next, write the controller parameters. Xylogics recommends reading 
the current parameters, modifying the ones in question, and then 
writing them back to the 752. This method allows you to change 
only those parameters that affect your system. 


152 Operation 


The 752 executes the IOPB slightly different than in Sections 7.1.4 
and 7.2.2: it performs this function by taking the values of all 
programmable parameters out of the IOPB and setting the appropriate 
flags and variables in its internal code. 


WRITE CONTROLLER PARAMETERS 


: SENT | RETURNED 
00 0s 45 
01 00 00 
02 | 00 XX 
os UWIAA o | x 
06 LLL o0 | o0 
Os 00 00 
06 00 00 
07 e Ht PeseESesEee CSE EEEEEE CESSES REESE a iH i 00 00 
08 Z Armon 7 NPRM C8 C8 


7 Aaa 
09 ora 10 10 


oa Aovsyg nase RECA 2 | 2 


os WE WII 


oc EPROM RELEASE LEVEL 00 00 
OD 00 00 
OF CONTROLLER TYPE 00 00 


re EPROM PART NUMBER HIGH 3 00 00 
si EPROM PART NUMBER LOW 00 00 
‘3 EPROM REVISION LEVEL 00 00 
og oe 


7 : 00 00 
| 4 00 00 
i 3 : 00 00 
el: NEXT 1OPB ADDRESS LOW |. oe | 00 00 


- _[lOPB CHECKSUM HIGH] Go 00 


“Tree)] Optionally LATUIAUIAIAIAT Returned 
Lee) Required Value 


Figure 7-3. Sample Write Controller Parameters IOPB 


D Requi 
Wt eerearane oe 
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READ/WRITE FORMAT PARAMETERS 


The format parameters are handled similarly to the controller 
parameters. Use extra caution when modifying the format parameters 
as improper selection may cause data corruption and/or unreliable 
operation. The data field size is the only parameter Xylogics 
recommends changing. 


Execute the IOPB with Interrupts 


Building on 752 functionality, enable interrupts for this example 
by specifying an interrupt level and vector. 


READ FORMAT PARAMETERS 


esa eel ae) 
NE LIA plese 


Bagley 


et 
cee 


WLLL, Fortnecution [oo ey TT venue 


Figure 7-4. Sample Read Format Parameters IOPB 
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152 Operation 


The 752 performs the operation almost identically to the examples 
in Sections 7.2.2 and 7.3.1, but with two additional steps. It 
makes sure the new format parameters are within the valid ranges. 
After the 752 sets RIO, it performs an interrupt sequence. 


Command Completion 


Enabling interrupts modifies the command completion. Software does 
not poll RIO when it is set, but may be off doing something else 
(probably waiting for an interrupt). When the interrupt occurs, 
hardware and software execute an Interrupt Service Routine (ISR) 
and process the interrupt. Hardware resets the actual hardware 
interrupt when the ISR is called. 


The ISR reads the address of the completed IOPB from the registers, 
and clears RIO. This completes the Read/Write Format Parameters 
operation. 


Returned Values 


Figure 7-4 illustrates the read portion of this subsection. ‘the 
752 returns the data for which it was last programmed. The sector 
size is set to 512 (200H). ‘The other fields are all set to the 
recommended values. 


READ/WRITE DRIVE PARAMETERS 


The Drive Parameters commands allow you to configure the 752 to 
your drive's size and parameters. Section 4.3 describes the size 
and configuration variables that may be modified with these 
commands. The operation is similar to both format and controller 
Parameters. 


152 Operation 


On a Write Drive Parameters command, the 752 performs an operation 
Similar to that of both controller and format parameters. The Read 
Drive Parameters function differs in that the 752 returns the 
number of physical sectors on the drive. 


The 752 selects the disk drive specified in the Unit bits. It 
times the interval between index pulses and, using this time value, 
counts the number of sector pulses. The 752 puts this count into 
Byte E of the IOPB. ‘This count is the number of sectors per track. 
See Figure 7-5. 
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132 Operation (continued) 
WRITE DRIVE PARAMETERS 
ie ae reek aa tet SENT | RETURNED 
lies Neca V/s a 
01 ee 00 | 00 
i" NN NNN o | ox 
04 ASUBFUNCTION CODE = 80) 80 80 
05 sea a a 77 WA 00 00 
5 a CM 7/7 TT ria 
OMA. Ea YY rs er 
CML: ees 00 | 00 
‘a ee eae ae eee so | 36 
: re Yi, of | os 
: ESE ‘7 
i: 00 | 00 
TLL, ey, Fee 
Figure 7-5 - Sample Write Drive Parameters IOPB 
FORMAT A TRACK 


Up to this point we have been initializing the 752. Initialization 
informs the 752 of the drive size, and parameters it requires 
before it can properly function. Now, let's format one track of 
the drive. The 752 can only execute Read and Write commands on a 
formatted track. (Typically, formatting is done only once in the 
lifetime of the media.) 
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7.6 FORMAT A TRACK (continued) 


WRITE FORMAT 


. 


A COMMAND CODE = TV 


SENT | RETURNED 


CoE, CRAY 0 | oc 
ee esas) eatin 0 | 


MSL LLL. 00 | oc 
WUIyy7yayn yyy yy 0 | on. 
CLM’ Spe 00 | oc 
eae, 00 | oc 
OE! | SNR 


DATA OR LINK ADDRESS HIGH 00 00 
DATA OR LINK ADDRESS 00 00 
DATA OR LINK ADDRESS 00 00 


(Ue OR LINK ADDRESS LOW 00 00 


VY 1 | PEL IRE Returned 
ZL Stn CL * 


Figure 7-6. Sample Write Format IOPB 


7.6.1 122 Operation 


The Format command is the first command in this tutorial that 
transfers data from the controller to the disk. The 752 operation 
for data transfer commands differs greatly from initialization 
commands. 
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7.6.1 


7.7 


152 Operation (continued) 
To format a track: 


1. The 752 still clears AIOP, sets BUSY, and reads the IOPB 
from memory. The next step occurs after the IOPB is in the 
752. 


2. The 752 decodes the function, and determines if a seek is 
required. All Write, Read, Write Extended, and Read Extended 
functions require the drive to seek to the commanded cylinder. 
Format is a Write Extended function; it requires the drive to 
seek. The 752 issues a seek to the drive by sending it the 
commanded cylinder number, 


3. The 752 waits for the drive to complete the seek; the drive 
indicates it's done by returning on-cylinder. 


4. When the drive is on-cylinder, the 752 determines if the 
current physical sector count for that drive is valid. If the 
count is not valid, it repeats the sequence in Section 7.5.1 to 
determine the actual physical sector count. The 752 proceeds 
to Step 5 when the count is valid. 


5. The 752 loads the data for the new sector header into the 
FIFO, waits for index, and writes the new header on Sector 0; 
it writes the data field with zeros, and writes the data field 
error correction code (ECC). 


6. The 752 repeats Step 5 for each sector on the track, except it 
uses the sector pulse instead of index to start the operation. 


7. The 752 updates the IOPB with the ending values, and 
completes the command. 


READ TRACK HEADERS 


Now that the track is formatted, read the headers back and verify 
they are correct. This command requires a data buffer; allocate 
Space in host memory just as you did for the IOPB. ‘The buffer 
length must be four bytes (per sector) times the number of sectors 
per track. (The Read Drive Parameters command gives you the number 
of sectors per track.) Make sure software passes the 752 the 
physical buffer address, not the virtual address. See Figure 7-7. 
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Tel READ TRACK HEADERS (continued) 


READ TRACK HEADERS 


00 le A tsenco ZA COnaNG «Ot 8 

0 Hn eee ana 
co (IPOeeIMM Se Iles: coe (twee ors tseee owe] |oeoy oo | x 
. Oey oo | x 
04 YU, ee ee oe GH 80 80 
. Ne 7 0 | 00 


06 LINK LIST LENGTH 


is [COUNT HIGH] HIGH | « . 
03 00 | . 0° 
\WWyywwwwiax== 1 IM DF = 


0 CNR OM ii, 99 + | 00 
0 LLL LL, 8 | 0 
en ee ee eee 


00 00 


CHM Sey oo | on 
Pp oie a 00 | on 


| Optionally THUAN Returned 
gg Required Value 


EL. iti eects eS 


Figure 7-7. Sample Read Track Headers IOPB 


Velen 752 Operation 
The Read Track Headers is the first command in this tutorial that 


transfers data to or from host memory. Data transfers to or from 
memory modify the 752 operation as follows: 
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Telek 152 Operation (continued) 


1. The 752 reads the IOPB, issues a seek, and decodes the 
command identically to the previous examples. 


2. The 752 waits for index from the drive. It tests the 
physical sector count to determine if it is valid. If the 
count is not valid, the 752 determines the actual count 
(see Section 7.5.1). 


3. After index arrives, the 752 synchronizes itself with the 
data in the header, and reads the data into its on-board 
FIFO. 


4. The 752 repeats Step 3 for each sector on the track, 
except it waits for the sector pulse instead of index. 
The actual physical sector count determines the number of 
sectors the 752 transfers into its FIFO. 


5. After the 752 transfers all sector headers into the FIFO, 
it begins the DMA. The controller transfers the data from 
the FIFO to host memory. 


6. When the 752 completes the DMA transfer, it places the 
updated information into the IOPB, and completes the 
command. 


7.702 Verifying the Data 


After the 752 completes the transfer, verify the data against what 
is expected. The data should be divided into groups having four 
bytes each. Each group describes a sector header. ‘he first 
sector header should have four bytes of 00. The second header 
should have three bytes of 00 and one byte of 01. The last byte of 
the third header should equal 02, etc. (see Section 8.3 for more 
information on headers). 


Header 1 Header 2 Header 3 


| 00 | 00 | 00 | 00 | | 00 | 00] 00 | 01] | 00 | 00 | 00 | 02 | 


Figure 7-8. Sample Sector Headers 
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7.8 WRITE DATA 


The format is valid after verifying the headers. This subsection 
describes a Write operation, and the following subsection describes 
reading back the data. Allocate space in host memory for the 
buffer, and set up a data pattern in this buffer; an incrementing 
count in the buffer will suffice. See Figure 7-9. 


WRITE DATA 


SENT | RETURNED 


LLL LL eo 
MLL ASN OW LLLILLILILIILLILLIZ_ 0 
Wd: ae YYYyYygwyywv om i oe 
Wyo yyw a 
OLLI. Lp LLL 00 | 0 
CMM Ly) ce 
MMS MEN ///77 00 | 0 
WM Tn 
ee 00 | oo 


Seenise: osegstsse SOS Te PSS Seis TE Ctaen Seer ST eter ae 


WLI a rey THUAN eeu oe 


Figure 7-9. Sample Write Data IOPB 
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7.8.1 


7.8.2 


7.9 


7.9.1 
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122 Operation | 
The 752 operation is similar to the previous examples; the 


differences are in DMAing data into the FIFO, and writing data to 
the disk. | 


The 752 starts the DMA from host memory to the FIFO after 
determining the drive is on-cylinder; it enables the disk sequencer 
when the FIFO contains one full sector of data. 


The 752 compares and verifies the header: the disk sequencer tests 
all the headers as they pass under the head, until it finds the 
sector designated for transfer. At the proper point in the sector, 
the 752 writes a new Sync byte, and then the data it read from 
memory. The 752, using the data to be written, generates and 
appends an ECC on the end of the sector. | 


Command Completion 


The command is complete as soon as the disk sequencer completes its 
Operation. The 752 puts the ending values into the internal IOPB, 
and performs an appropriate update. 


READ DATA 


In Section 7.8 the 752 wrote the data to the drive on Sector 0, 
Head 0, and Track 0. ‘This subsection describes reading back the 
data and verifying it. You must allocate a data buffer for the 752 
to write the data in memory. After allocation, it is a good idea 
to fill the buffer with a known pattern that differs from the 
expected data. See Figure 7-10. 


152 Operation 


The 752 treats this command like the previous operations, except in 
the way it DMAs the data into the FIFO and writes the data to the 
disk. 


The 752 enables the disk Sequencer as soon as the drive is 
on-cylinder. After the controller finds the correct header, it 
transfers the data from the disk to the FIFO. As soon as the first 
sector of data is available from the buffer, the DMA controller 
DMAs the data from the FIFO to host memory. ‘The transfer is done 
when the DMA controller completes the DMA, 


Command Completion 


The 752 completes the command when the DMA to memory is complete. 
The next subsection describes how to verify the data. 
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7.9.2 Command Completion (continued) 


READ DATA 


ee mote epee | ee Ceeeen ee B SENT | RETURNED 
02 


FOONE ||| CHEN YA scm ACLU cormane CODE =_2V/// 


A SUE TA 


| ERT a | o 
7 ti = LIP 00 | 00 
SS eee el i 
WML LLL 0 | 00 
GF Oe 0 | oc 


Ce a oe 


coors TMM ee" 
=] Required Value 


QQ crartxecution 
Figure 7-10. Sample Read Data IOPB 


7.9.3 Verify Data 


First, make sure the buffer was modified. If it was not modified, 
either an error occurred, or software specified the wrong buffer 
address. Next, compare the data written with the data read; they 
should match. 


Rev. A. June 15, 1987 93 


XYLOGICS 752 Disk Controller User's Manual 


7.10 MULTIPLE SECTOR TRANSFERS 


You can repeat the steps in Sections 7.8 and 7.9 using a larger 
sector count. The 752 crosses head and cylinder boundaries, as 
required, to complete the required number of sectors. Be sure to 
allocate enough buffer space for the increased sector count, 


7.11 SUMMARY 


This section was an exercise in testing the 752's functionality in 
your system. The steps are basically the same when the software 


driver controls the 752. (Operating systems always allocate the 
buffers. ) 
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SECTION 8: SPECIAL FUNCTIONS 


8.0 GENERAL 


This section describes how to implement the various 752 special 
functions. Each subsection descibes how minor functions implement 
a given major function. 


8.1 READ DEFECT MAP 


The 752 reads the data recorded on the media by the manufacturer 
that describes the location and length of factory-detected media 
defects. The defect map's format must conform to the following 
specifications: M2331/M2333 Disk Drive Engineering Specification; 
Fujitsu. LTD. Doc. No. BO3P-4760-0101A; and CDC _ Product 
Specification No. 64400400. 


8.1.1 The Defect Map 
The header format is divided into two parts. The first part of the 
format is a fixed sector format; the second part is a variable 
sector format. The fixed sector format is normally included in the 
first 56 bytes following the index mark. The 752 does not support 
the variable sector format. 
The following rules apply to defect recording: 


1. The position ot a defect is listed in bytes (hex) after the 
index mark, plus or minus one byte. 


2. The length of a defect is in bits (hex), plus or minus one bit. 
3. The unused defect locations are all zeros. 


4. Every track is recorded with this defect format whether defects 
exist or not. 


5. A track that has more than one defect may be flagged as 
defective. Log the first four media defects on the track. 


6. Figure 8-1 shows the format when there are no defects in the 
first 105 bytes after the index mark. 
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8.1.1 The Defect Map (continued) 


39 40 43 44 47 «648 SS! S82 $s 


¢ 14 29 30 31 32 33 34 «35 
an 2nd Defect 3rd Defect 4th Defect 
Length Length | Pos. }| Length Length 
2 2 2 2 2. .2 


ze High Order Bit 
Defective Track = 1 


36 
Ist Defect 


Figure 8-1. Defect Map Format 


7. Figure 8-2 shows the format when the beginning of a defect is 
located between Bytes 10 and 55; 60 bytes of zeros are added to 
Gap 1. In the extended defect map format, the defect map is 
always relocated to a defect-free area. 


index 


55 89 90 92 94. 95 96 99 100 103 104 107 108 Htt 442 ws 


— 
— § AGS. ni 


eaira eae ee ee 
Defect 
Figure 8-2. Extended Defect Map Format 


8.1.2 Read the Defect Map 


Set up a 24-byte buffer in memory. Issue an Extended Read with a 
subfunction of Read Defect Map. Since the defect maps do not use a 
checksum, verify the data. 


8.1.3 Verify the Data 


The first byte in the buffer should be a 19H. ‘This is the second 


o£ two Sync bytes. The head and cylinder addresses should agree. 
The last byte should be an FOH. 
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8.1.4 


8.2 


8.2.1 


8.2.2 


Determining the Location of a Defect 


The position of a defect is provided in bytes from the index mark. 
You must convert this value to a sector number before using it for 
defect mapping. The drive switch settings determine the actual 
number of bytes per sector. Divide this value into the defect 
position. This number, truncated, points to the physical sector 
containing the defect. Adjusting this physical sector number by 
any interleaving or skewing scheme determines the logical sector 
number for remapping. 


FORMATTING 


This subsection describes formatting, including how to set the 
number of spares for use in media defect handling and setting the 
sector size. 


Allocating Spare Sectors 

You must allocate spare sectors at format time. The Write Drive 
Parameters command allows setting the maximum size parameters for 
the drive. Any sectors in excess of the drive size parameters are 
marked aS Spares. For example, a drive with 46 physical sectors is 


Specified as having only 45 in the Write Drive Parameters command. 
The 752 formats 45 normal sectors and 1 spare sector. 


A separate variable (max sector/last head) specifies the number of 
sectors on max head. This allows extra spares on max head for use 
with cylinder sparing. Given the above example, max sector/last 
head is set to 40. The 752 formats the last head of the same drive 
with 40 normal sectors, and 6 spare sectors. 


Specify Sector Gap Size 


First a note of caution, don't do this. Modifying the gap sizes 
may reduce your disk subsysten'’s performance. ‘The drive interface 
has many specifications and parameters to which you must adhere. 
Slight miscalculations may not show up in the engineering lab, but 
may cause unreliability in the field. The failure modes may be 
undetectable because field lengths are only marginally long enough. 
A word to the wise: if you decide to use this feature, please be 
very careful. 


Xylogics' values work with all standard SMD drives (see Sections 
4.4.6 through 4.4.8). Modified values may work with same drives, 
and cause unreliable results with others. See Figure 8-3. 
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8.2.2 Specify Sector Gap Size (continued) 


The following subsections outline the parameters that affect each 
of the gap sizes. Many of the parameters that affect the gap sizes 
are specifications for the drive in use. Drives from different 
manufacturers, and even drives in one manufacturer's line, may have 
very different specifications. 


Sector Pulse — JLT 


Date [ee | 


| ] l 

Write splice i | i a | 

Fields = (13 ] [*]sxsm_ J. | I 

Format | GAP 1 |JHOR|GAP2|] DATA [cars| capt | 
4 SYNC * SYNC ®ecc SYNC —* 

Format. 


pe ee ee | 


Write-bete- J"; «3. =: ee eee 
Py wht | 


Read Gate ig ME me eee eee eee 


Write 


reel rT | 
Seu Cte | | Ld 


Read Gate 
Search Gate a ee tg L 


PREVIOUS CURRENT SECTOR NEXT 


Figure 8-3. Sector Gap Sizes 
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8.2.2.1 Field 1 — Read Gate Delay - Gap l 


Field 1 specifies the time in bytes from one byte past the leading 
edge of sector or index to when Read Gate is asserted. The 
applicable drive specifications include head settling time, 
allowing enough time to lock the Phase Lock Oscillator, and the 
minimum Write Gate to Read Gate timing. Field 1 also provides for 
skipping over the write splice area. 


The head settling time is the time required for the heads to settle 
after the drive completes a seek. We do not know how long before 
the sector or index pulse the seek completed, therefore this field 
must be large enough to encompass the head settling time. 


When subtracted from Field 3, this field indicates the amount of 
time left for the Phase Lock Oscillator in the drive to lock onto 
the data. Drive requirements vary from 3 to 16 bytes. 


When Write Gate is deasserted, a minimum time must be allowed for 
the read heads and amplifiers to stabilize. In a multisector 
transfer, Write Gate is deasserted after the last sector, and Read 
Gate is asserted for reading the next header. Figure 8-3 indicates 
this time as "C". Field 1 and the remaining bytes in the sector 
after Field 7 comprise this critical time. Drive requirements are 
usually in the 10 to 12 microsecond range. 


Write Splice: as Write Gate is asserted (or deasserted), the 
changing write current causes a magnetic field to build (or 
collapse) which "writes" garbage onto the disk. This is called the 
write splice, and it occurs whenever Write Gate is asserted or 
deasserted. 


8.2.2.2 Field 2 — Sync Search Delay 
Field 2 is the delay from asserting Read Gate to when data is 
compared for the Sync byte. Field 2 masks any read data from being 
detected as a sync until the data is stable. 
Field 3 is equivalent to Gap 1. Fields 3 and 1 together define the 


amount of time allowed for the Phase Lock Oscillator (PLO) in the 
drive to lock up. See Section 8.2.2.1. 
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8.2.2.4 


8.2.2.5 


8.2.2.6 


8.2.2.2] 


8.2.3 


Rev. A. 


Field 4 - Gap 2 


Field 4 is equivalent to Gap 2. It is the time (in bytes) between 
the end ot the Header ECC and the Data Sync byte. fMThis field 
includes the time required to allow the PLO in the drive to sync to 
the data and to skip the write splice. On a Write command, Write 
Gate is asserted four bit cells after Read Gate is deasserted. 
This field is actually four bits longer than specified. These four 
bits are used to test the header. 


Field 6 — Read Gate Delay 


Field 6 asserts Read Gate after the write splice during Gap 2. The 
time left over, Field 4 minus Field 6, is the time allowed for the 
PLO in the drive to lock up. 


Field 7 — Write Continuation 


The write continuation field is necessary so that when Write Gate 
is deasserted, the collapsing magnetic field does not splash over 
the ECC that was just written. ‘The end of Field 7 is the beginning 
of the minimum Write Gate to Read Gate period described in Section 
8.2.2 Pe ie 


Head Switch Time 


The 752 requires 6 bytes of time after Field 7 to switch heads. If 
the sector size is too short to allow this 6-byte field, the 752 
will miss revolutions on every head switch. ‘This should not be a 
problem; typically, the minimum Write Gate to Read Gate time allows 
for this field. 


Format Interleave 


The 752 can optionally format with an interleave pattern from 2:1 
to 16:1. Specify the interleave factor when writing the format 
parameters; it is invisible to the operating system. 


Interleaving can increase the throughput of a disk subsystem on a 
fully loaded system by effectively cutting the disk speed in half. 
On a contiguously formatted pack (1:1 interleave), the sectors 
increase by one each time. As the disk spins, the sectors arrive 
under the head in the following order for a 32-sector disk: 


012345678910 11 12 13 1415 16 17 18 19 20 21 ...31 
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8.2.3 


8.3 


8.3.1 


Format Interleave (continued) 


If you interleaved the same disk with a 2:1 interleave factor, it 
would look like this: 


016117 218 319 4 20 5 21 6 227 23 8 24 9 2510 ...31 


The 2:1 interleave allows the 752 two sector times to transfer a 
sector to memory. For example, if you are transferring sectors 0 
and 1 to memory, the following occurs in each case. 


In l:l interleaving, when the first sector finishes reading from 
the disk, the next sector is almost under the head and ready for 
reading. At this time there must be enough roam in the buffer or 
the 752 misses a revolution. 


In 2:1 interleaving, when the first sector finishes reading from 
the disk, the next sector is still a full sector time away, thereby 
Giving the 752 twice the time to empty the buffer to memory. ‘The 
scheme above shows the extra sector time as sector 16. 


Interleaving schemes from 2:1 to 15:1 are software programmable. 
Since the 752 determines the drive's sector location by comparing 
headers, you can use the Write Track Headers command to custanize 
the interleaving scheme to your application. For example, if your 
system transfers data in 2K-blocks, then the most effective 
interleaving scheme may he: 


0123 16171819 4567 20 21 22 23 891011... 


MEDIA DEFECT HANDLING 


There are three methods for handling media defects: 1) slipping a 
sector; 2) remapping a sector to a new sector on the last head of 
that cylinder; and 3) remapping the entire track to a different 
track on the disk. 


Sain a Seceae 


Slipping a sector requires using the Read and Write Track Headers 
commands to mark the bad sector and slip the rest of the sectors 
into the next position on the disk. Figure 8-4 shows an 8-sector 
track before and after slipping Sector 3. 
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8.3.1 Slipping a Sector (continued) 


| of|21if4]2 7] 3 | 4 | «5 | 6 | 7 | Spare | 


| | 1 | 2 | Bad] 3 | 41 5 | 6 | 7 | 


Figure 8-4. Sector Slip 


8.3.1.1 Sector Slip Procedure 
1. Determine which sector is bad by writing and reading the track 
with several patterns, and/or by using the manufacturer's 
defect map information. 
2. Read the track headers into a buffer in host memory. 


3. Compare each header with the bad sector's header. 


4, Atter locating the bad sector, mark it by writing EEH into each 
of the four header bytes (see Figure 8-6). 


5. Test the last sector to determine if it is a spare. If it isa 
Spare, continue; if not, you must find another sparing method. 


6. Move each sector header into the next location, "slipping" the 
sectors down the track (see Figure 8-4). 


7. Write the track headers back to the disk. 


The following figures depict 752 headers: 


| Sync | Cylinder Low | Cylinder High | Head | Sector | 


Figure 8-5. Normal Header 


| Sync | EE | EE | EE | EE | 


Figure 8-6. Header Marked Bad 
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8.3.1.1 Sector Slip Procedure (continued) 


Figure 8-7. Header Marked Spare 


| oo | 00 | 00 | 00 | 00 


Figure 8-8. Runt Header * 


* Tnis header is invisible in normal 752 operation. 
It appears here for informational purposes only. 


| Sync | New Cyl Low | CC | New Cyl High | Head | 


Figure 8-9. Track Remap Header 


8.3.1.2 Advantages of Sector Slipping 
A full track of information is still transferred in one revolution 
ot the disk. Other methods of sector slipping require two or more 
revolutions to transfer one track of information. 

8.3.1.3 Disadvantages of Sector Slipping 
Having one or more spares on each track uses disk space 
inefficiently. 

8.3.2 Cylinder Sparing 


Cylinder sparing is Similar to sector slipping, except the Spares 
are on the maximum head of the cylinder. 
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8.3.2.1 Cylinder Sparing Procedure 
1. Determine the defective sector. 


2. Read the track headers and mark the defective sector bad (see 
Figure 8-6). 


3. Write the track headers back to the disk. 
4. Read the track headers on the maximum track of that cylinder. 


5. Find a spare sector; it contains four bytes of ODDH. 
(see Figure 8-7.) 


6. Put the bad sector's header into this sector. The header 
contains the head and sector values for the sector being 
remapped on the original track. 


7. Write the track headers back to the drive. 


8.3.2.2 Advantages of Cylinder Sparing 


Cylinder sparing uses less disk space for remapping bad sectors. 
You may decide to allow only 10 spares for a drive with 20 heads. 
Sector slipping is less efficient as it requires a minimum of 20 
sectors per cylinder for this drive (one per head). 


8.3.2.3 Disadvantages of Cylinder Sparing 


Cylinder sparing is slower than sector slipping. ‘The 752 looks for 
the requested sector for one revolution plus one sector on the 
Original track; then it switches to max head and looks for another 
revolution plus one. sector. This method takes up to three 
revolutions to transfer one track of information (assuming only one 
bad sector). 


8.3.3 Track Remapping 
The 752 remaps an entire track to another location on the same disk 


Grive by writing the defective track's headers with a code and new 
disk address. 
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8.3.3.1 Track Remapping Procedure 
1. Read and save the defective track's headers. 


2. Allocate space for a write track headers buffer. Each header 
has OCCH in the second byte. The first, third, and fourth 
bytes contain the new Head, Cylinder High, and Cylinder Low. 
Write this information to the defective track with a Write 
Track Headers command. See Figure 8-9, 


3. Write the track headers that were read in Step 1 to the 
destination track with a Write Track Headers command. 


8. 3 e3e2 Advantages of Track Remapping 


Track remapping is useful in sparing tracks with very large or 
multiple defects. 


8.3.3.3 Disadvantages of Track Remapping 


Track remapping is relatively slow as the 752 must seek to the 
first track and then determine if it has been remapped. Then the 
752 seeks to the spare track area (usually at the end of the disk). 
This sequence can add up to four revolutions to the 752 overhead. 


8.3.4 | Recommended Remapping Procedure 


Xylogics recommends using all three methods of defect mapping. 
Allowing one spare sector per track takes care of 95% of the media 
defects. An additional 0.2% of the sectors on the cylinder to be 
spared on the last head provide up to 99% remapping. Allowing 
three or four tracks for remapping should provide a defect-free 
media. Allocating this amount of disk space for defect handling 
totals 2% of the media. Having two spares per track on the same 
Grive (a Fujitsu Eagle with 512—byte sectors) uses 4% of the media. 


8.4 CHAINING AND MULTIPLE I/O REQUESTS 


The 752 has two ways of speeding up multiple IOPB execution. One 
method allows the driver to chain IOPBs together, and then give the 
752 a command-chain. The second method allows the driver to add 
IOPBs to the 752's queue by the same procedure as starting the 
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8.4.1 Chaining 
Each IOPB has a Chain Enable (CHEN) bit and a Next IOPB pointer. 
IOPBs can be chained together by setting CHEN and having the Next 
IOPB pointer point to the next IOPB to be executed. Each IOPB in 
the chain points to the next, and, in order to stop the chain, CHEN 
is not set in the last IOPB. 
NOTE 


The Next IOPB Address is the physical address, not the 
virtual address. 


8.4.2 Multiple I/O Requests 


The following procedure allows you to add IOPBs to the 752 queue: 


1. ATIOP must be clear. If it is not clear, wait; it normally 
clears within 100 microseconds (see Sections 3.3.2 and 4.2.1). 


2. Write the five IOPB address registers to point to the beginning 
of the IOPB (chain). 


3. Write AIO. 


8.4.3 132 Operation 


The 752 treats IOPBs the same, regardless of how they were added to 
the queue. Overlap seeks function only when they are enabled and 
the 752 is working with a queue or chain of IOPBs. 


8.5 ERROR RECOVERY 


The 752 may automatically retry operations that have errored. ‘Two 
options are available. One option involves retrying drive fault- 
and seek-type errors. The other option involves the retry 
algorithms for ECC recoveries. The Read and Write Controller 
Parameters commands enable or disable these options. 


8.5.1 Automatic Operation Retry 
The 752 automatically retries an operation if the reason for the 


initial failure is a seek error or drive fault. Setting ASR with a 
Write Controller Parameters command enables this option. 
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8.5.2 ECC Error Recovery 


ECC algorithms have a much better chance of recovery if the 752 
retries the operation before using the ECC correction. The 752 
retries the Read operation once before applying the ECC correction 
if RBC is set. Set RBC with a Write Controller Parameters command. 


There are three options for applying ECC correction. Using Mode 0, 
the 752 provides the correcting pattern and offset for the driver 
to go and correct the actual error in memory. Mode 1 flags the 
fact that an error occurred, but does not stop the transfer to 
calculate any correction information. Mode 2 calculates the 
correction information and applies it to the data in host memory. 


8.5.3 Using the Error Recovery Options 


Changing the appropriate controller parameter enables or disables 
the error recovery options. Once set, the 752 takes care of 
applying the retries as requested. The 752 provides a completion 
status to indicate a recovery operation took place. The driver 
applies the ECC correction if ECC Mode 0 is used. If a retry 
fails, the Completion Code reflects the fatal error. 


8.6 MAINTENANCE MODE 


Firmware Supports a non-IOPB driven Maintenance mode. It allows 
you to perform basic testing within the 752 by setting Control bits 
in the CSR and entering the desired test number and data through 
the address registers. This firmware also provides a window 
through which internal registers may be examined or modified. 


8.6.1 Register Use in Maintenance Mode 


The Function Code in the Test Number Register determines whether or 
not the 752 uses the Input Data Byte and Output Data Byte Registers 
(see Table 8-1). Familiarize yourself with the Control and Status 
Register before reading this section (see Section 3.3). 


Test Number or Function Code 
Input Address Low 

Input Address High | 

Input Data Byte (If Required) 
Output Data Byte (If Required) 
Control and Status Register 
Fatal Error Register 


OG WON OWE 


Table 8-1. Register Use in Maintenance Mode 
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8.6.2 
8.6.2.1 


8.6.2.2 


8.6.2.3 


Rev. A. 


Maintenance Mode Protocol. 
Executing a Maintenance Command or Entering the Maintenance Mode 


First, set the Maintenance Mode (MM) and AIO bits. MThis forces 
entry into the maintenance kernel. ‘The kernel initializes the CSR 
and Poll mask and sets the Remove IOPB (RIO) bit; then clear RIO. 


The kernel expects the Input Address Low Register to contain a 
IMaintenance test number or function code for execution. Data may 
be expected or may be returned (see register layout). | 


BUSY and AIO are configured for polling. Setting BUSY and AIO 
selects the register image teSt; clearing BUSY returns control to 
the maintenance kernel. 


AIO causes the maintenance firmware to read and decode the command 
string from the Input Address Registers. After successfully 
decoding the command string, the firmware echoes it (command, 
address, and data) to the Output Address Registers and clears AIO. 
This acknowledges receipt of and attempts to execute the requested 
command. After completing the requested command, the 752 updates 
the Output Address Registers with test-pertinent data and sets the 
RIO bit. The AIO/RIO protocol is identical to Normal mode. (RIO 
indicates the end of firmware involvement and valid contents in the 
Output Address Registers. ) 


Since each test and its expected results are different in nature, 
the Output Address Registers hold the test result information 
(address, data, etc.). In any case, the firmware sets RIO upon 
command completion; it sets the Fatal Error bit if a failure occurs 
or if host software issues an illegal command. 


Exiting the Maintenance Mode 

To exit the Maintenance mode, clear MM and RIO, and set AIO. This 
returns control to the Normal mode kernel. ‘The 752 acknowledges by 
setting RIO. 

Diagnostic Considerations 


The Input/Output Address Register Verify is the first test the 
diagnostic should execute. 


Firmware flags the power-up self test failures by setting the Fatal 
Error bit while leaving the Maintenance mode bit set. Firmware 
saves the self test error numbers internally until it verifies the 
Input and Output Registers. 


June 15, 1987 | 108 


XYLOGICS 752 Disk Controller User's Manual 


8.6.2.4 Register Tests 


You must request entry into the Maintenance mode to invoke the 
Register test. After the firmware acknowledges the request, you 
should set BUSY. BUSY remains set during this test. 


NOTE 


You must enter the Maintenance mode as a separate step 
because the Normal mode firmware does not allow setting 
BUSY (defined as RMM when Maintenance mode is enabled). 


Writing the Input Address Registers, followed by AIO, signals the 
firmware to copy the data to the Output Address Registers. 
Firmware sets RIO when it completes the copy. Host software should 
then clear RIO. 


Clearing the BUSY bit exits this test and returns the 752 to 
Maintenance mode. 


8.6.2.5 Test Variables 


Some of the internal tests require the address and data to perform 
their particular function. On-board memory has space allocated for 
this data. These locations are loaded with default values for 
initial use. However, you may alter these variables through the 
Manual mode. (As the internal tests are defined, the protocol and 
results expected will be made available.) 


8.7 MULTIPROCESSOR SUPPORT 
The 752 has several options that make multiprocessor environments | 


easier to support: the programmable interrupt vector, interrupt 
level, register address modifiers, and busy semaphore. 


8.7.1 Interrupts 
Each IOPB specifies the interrupt level and vector for that 


command. In a multiprocessor environment, each processor can have 
its own assigned interrupt level and vector. 
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8.7.2 


8.7.3 


8.8 


8.8.1 


8.8.2 


Register Busy Semaphore 


RBS allows multiple processors to share the registers without 
colliding. Hardware supports the RBS bit. The register access 
protocol involves reading the CSR. If RBS is clear, the host has 
control of the register, and retains control until it clears RBS in 
the Control Register. If the first read to the Status Register 
indicates that RBS is set, then another host has control of the 
register and this host must wait until RBS clears. 


The 752 sets RBS immediately after a host reads the CSR. If a host 
attempts a read, and RBS is clear, the 752 sets RBS; any successive 
reads by other hosts will "see" that RBS is set. When the host 
using the registers is done, it must clear RBS. Clearing RBS and 
setting AIO can occur in the same register write. Clearing RBS 


without having control of the registers violates the register 


protocol. 


Address Modifiers 


The address modifiers can be used to assign separate address space 
for each of the processors. 


SOFIWARE CONTROL 


The 752 has many parameters that can be modified by software 
control. The parameters can be set in bulk with three write 
parameters commands: Write Format Parameters, Write Drive 
Parameters, and Write Controller Parameters. 


Modifying a Single Parameter 


The best method for modifying a single parameter (assuming the 752 
was previously set up) is to first execute a read parameters 
command for the associated parameter block, modify the single 
parameter, and then write the parameter block back to the 752. 


Modifying a Group of Parameters 


Use the same method as in Section 8.8.1, or set all the parameters 
in the specific IOPB and execute the appropriate write parameters 
command. For example, Fields 1 through 7 and the interleave factor 
must be set to the appropriate values before issuing the Write 
Format Parameters command. The 752 sets all parameters to the new 
values contained in the IOPB. 
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8.8.3 Parameter Reference Point 


After the 752 is working as intended, read the parameters and save 
the information for future use. 


8.9 SCATTER/GATHER 


The Scatter/Gather feature is used in conjunction with standard 
Read and Write commands. In a Scatter Read, the 752 transfers the 
data to up to 32 blocks of memory. Gather Writes gathers data from 
up to 32 blocks of memory and writes it to the disk. ‘The size of 
each memory block must be an even byte count and less than 
64K—-bytes long. The blocks may be scattered throughout memory. 


8.9.1 Scatter/Gather Link List 


You can determine the length of the linked list by multiplying the 
number of elements in the list by 8 (each element is 8-bytes long). 
All data addresses must be on word boundaries and the byte count 
must be even. For Read and Write operations, enter the number of 
elements in the linked list into Byte 6, bits 3 through 7. A zero 
in this field indicates the linked list has 32 elements. 


1 00-01 Byte Count (Multiples of 2) 

02 Reserved 

03 Data Address Modifier 

04-07 Data Address (Word Boundaries Only) 
2 08-09 Byte Count 
n xx 


Table 8-2. Scatter/Gather Link List 
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8.9.1 


8.9.2 


Scatter/Gather Link List (continued) 


Link Field Value Decimal Equivalent 
0 32 
1 1 
2 2 
9 9 
A 10 
B 11 
1E 30 
1F 31 


Table 8-3. Link List Field Values 


Setting Up a Scatter/Gather Transfer 


The Data Address and Modifier bytes in the IOPB should now point 
to the start of the linked list. The linked list length field 
should give the total number of elements on the list. 


Elements of memory descriptors comprise the linked list. Each 
element describes the starting address and the length in bytes 
of the memory block. The sum of the byte count of all the 
elements in the linked list must equal the sector count times 
the sector size in bytes. 


The IOPB and Linked List in Figure 8-10 illustrate a Read 
transfer to 6 blocks of memory. ‘The sector size in this case is 
5l2-bytes per sector; we are transferring 3 sectors of 
information. The 752 transfers the first 16 bytes of data from 
each sector to a separate data buffer. It scatters the bulk of 
the data, 512-bytes per sector, into memory as 3 blocks having 
512 bytes each. 


Set SGM and execute the IOPB in Figure 8-10. 
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8.9.2 


8.9.3 
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Setting Up a Scatter/Gather Transfer (continued) 


SCATTER / GATHER READ COMMAND 


"76s ]s#lo2tlztitl 
oo [ERRS| DoNE| cHEN| som | COMMAND 
01 COMPLETION CODE 
oz | DPB | sr] CSE | wrpr| DFLT | sker] oncl pRDY_ 
03 
04 SUBEUNCTION 
os [rixp [RDP [psex] 0 |. on 
06 
07 
08 
09 | COUNT LOV 
OA | CYLINDER HIGH 

CYLINDER LOW 

EAD 
SECTOR 


ro) 
oO 
ee 


oO 
tw 


oOo oO 
oO 


DATA / LINK ADDRESS MODIFIER 
NEXT IOPB ADDRESS MODIFIER 

DATA / LINK ADDR HIGH 

DATA / LINK ADDRESS 

ATA / LINK ADDRESS 

ATA / LINK ADDR LOW 

EXT IOPB ADDRESS HIGH 

EXT IOPB ADDRESS 

NEXT IOPB ADDRESS 

NEXT IOPB ADDRESS LOW 

IOPB CHECKSUM HIGH 

IOPB CHECKSUM LOW 

ECC PATTERN WORD HIGH 

ECC PATTERN WORD LOW 

ECC OFFSET WORD HIGH 

ECC OFESET WORD LOW 


— i lOO 
VT ow PrP OWI DU DWH FF OM MX 


oe 


ra 


Figure 8-10. 


152 Operation 


12H 
OH 
OH 
OH 
OH 
02H 
30H 
OH 
OH 
O3H 
OH 
02H 
01H 
04H 


= 02H 


Scatter/Gather Transfers 


OH 
OH 
OH 
OH 
19H 
OH 
OH 
OH 
OH 
OH 
OH 
OH 
OH 
OH 
OH 


000204 LINK LIST 

00-01 
02-03 
04-05 
06-07 
00-01 
02-03 
04-05 
06-07 
00-01 
02-03 
04-05 
06-07 
00-01 
02-03 
04-05 
06-07 
00-01 [_BC=0010H | 
02-03 
04-05 
06-07 |_DAL=1020H | 
00-01 
02-03 
04-05 
06-07 


The 752 proceeds as if doing a normal read until it starts the data 


transfer into memory. 
the DMA processor; 
address for each element on the list. 


The contents of the linked list now controls 
it gives the processor the byte count and 
The processor takes the data 


out of the FIFO and transfers it to memory as described in each 


element on the list. 
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8.10 


8.11 


8.12 


DMA THROTILE / THROTILE DEAD TIME 


The 752 always transfers IOPBS in Word mode; it uses the last 
specified values for the throttle and throttle dead time. 


Host software can set the Throttle Dead Time (TDI) field in the 
Controller Parameters IOPB. ‘This value defines the time that the 
752 waits before attempting to regain control of the bus between 
throttle bursts. There are four valid TDT values. 


TO? Value Time 
0 0 microseconds 
1 S62 7 
2 6.4 " 
3 12.8 . 


Table 8-4. Throttle Dead Time Values 


IOPB CHECKSUM 


While debugging the driver, you may choose to append the checksum 
to the IOPB. The checksum is the sum of Bytes 0 through 17 in the 
IOPB, and is expressed as a 16-bit quantity. The 752 generates a 
checksum with the data from the IOPB and compares it to the 
appended checksum; a miscompare causes a fatal error. If AUD and 
ICS are set, the 752 appends a new checksum as it updates the IOPB. 
If you want to disable the checksum, the Write Controller 
Parameters IOPB must have a valid checksun. 


FIXED/REMOVABLE MEDIA 
Any physical drive with fixed and removable media, like the CDC 


CMD, or LMD, is accessed as one logical unit (FIXD is clear for the 
removable media of Unit 0, and set for the fixed media of Unit 0). 
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8.12.1 Head Offset 


The head offset refers to the bit(s) that must be set during a 
drive head select sequence to select between the fixed and 
removable portions of the drive. Host software must specify a 
headoffset value for fixed/removable drives: one for the removable 
portion ot the drive, and one for the fixed portion. The offset 
value is a hexadecimal number that the 752 adds to the head number 
in order to select either the fixed or removable portion of the 
disk. Two such fixed/removable drives are the CDC Lark and CD. 
The head offset value for the removable portion of a CMD is zero; 
the head offset value for the fixed portion is 10H. Reference the 
appropriate vendor manual to determine the head offset values for 
the £1xed and removable portions of the disk. 


8.13 EMBEDDED SERVO DRIVES 


The 752 inherently supports embedded servo drives. Configure the 
drives to seek on every head select. The 752 always waits for an 
on-cylinder condition before starting a new sector. 


8.14 DUAL PORTED DRIVES 


Some SMD drives have an optional second port that connects to a 
second disk controller. This allows two computers to access a 
Single disk drive. 


Dual ported drives are requested by executing a normal Unit Select 
(which is a normal controller function, invisible to the software). 
Once selected, the drive port remains selected and reserved until a 
Release command is issued. Deselecting the drive without a release 
leaves the drive deselected but reserved, and unavailable to the 
other port. If the Release Dual Port (RDP) bit is set, the 752 
executes a Release command after completing the IOPB. RDP should 
be set for normal transfers to a dual ported drive, unless you are 
trying to lockout the other controller. 


Priority Select or Trespass is available if the other controller 
refuses to give up the port. This is an override command, and as 
such forces connection to a port, regardless of the other port's 
activity (including writing to the disk). Priority Select provides 
emergency access to the disk, but you must understand that it can 
Clobber the disk if the other controller is updating the directory. 
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8.14 


8.14.1 


8.15 


DUAL PORTED DRIVES (continued) 


Leaving the disk drive in a released state when it is not being 
accessed provides equal access for both controllers. 


NOTE 


When using dual ported drives with read ahead, you must 
configure the drive to release the port via a timeout 
mechanism. If software sets RDP, the 752 prematurely 
releases the port while read ahead is active. If 
software must set RDP to function properly with a 
particular dual ported drive, then you must disable read 
ahead by setting DRA. 


Software Write Access Control 


Host software must control access to the drive so that the two 
computers do not simultaneously write onto the same sectors or 
directory. This can corrupt the file systen. Software can 
implement several methods for providing this control. 


One control method allows one computer read/write access, and the 
other only read access. A second method employs disk partitioning, 
allowing each controller read/write access to its own partition, 
and read only access to the other controller's partition. The most 
commonly used method allows both controllers read/write access to 
the files, but only one controller has read/write access to the 
directory and allocation maps. 


Another method for controlling drive access is to lock out the 
other controller while doing a write. Clearing RDP in the IOPB 
locks the other port by not releasing the first port. You have to 
lock out the other controller from the time you read the allocation 
Iap and directory, to when both are updated after the transfer. 
The IOPBs from the first read to the next to the last write have 
RDP clear; the last write has RDP set. 


READ/WRITE HEADER, HEADER VERIFY, DATA, AND DATA ECC 


This maintenance command tests the controller and software driver. 
It enables simulating ECC errors to verify the ECC is working. ‘The 
operation includes reading a sector with its header into memory, 
modifying the data and then writing the sector back to the disk; 
the 752 does not recalculate the ECC. 
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8.15 


8.15.1 
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READ/WRITE HEADER, HEADER VERIFY, DATA, AND DATA ECC (continued) 


The data read back is either 12 or 14 bytes larger than the data 
sector size (depending on EC32's status). For example, given a 
5l2-byte sector size, the 752 returns 524 bytes if EC32 is set, and 
526 bytes if EC32 is clear. Table 8-5 shows the relationship 
between EC32's status and the returned data. 


Byte EC32 Clear Byte ECG32 Set 
0-3 Header * 0-3 Header* 
4-7 Redundant Header* 4-7 Header ECC 
8— (n+8) Data 8—(n+8) Data 

(n+8) —(n+14) 48-bit ECC (n+8)—(nt12) 32-bit ECC 


* Figures 8-5 through 8-9 describe the header information 
Table 8-5. EC32 vs. Returned Data 


Simulating an ECC Error 


To simulate an ECC error, read a sector by issuing a Read Header, 
Header Verify, Data, and Data ECC command. Then change a data byte 
or bit, and write the sector back by issuing a Write Header, Header 
Verify, Data, and Data ECC command. Reading this sector with a 
normal Read command should return an ECC error. 


There are two common problems associated with Simulating an ECC 
error. First, the corrected data byte may be next to the one in 
error. Second, the data may not be serially written to the disk as 
you see it on your terminal screen. Thus, a "2-bit error" crossing 
a byte boundary may be uncorrectable. 


The 752 usually accesses memory in Word or Longword mode, but 
corrects data in ECC Mode 2 via byte transfers. Since some bus 
adapters reverse the byte addressing scheme within a word, the 752 
corrects the wrong data. ‘The only solution for this situation is 
to either correct the adapter or use ECC Mode 0. 


The serial data is placed on the disk with bit 0 of each byte 
first. Table 8-6 shows a simulated 2-bit error crossing byte 
boundaries. Since the two bits in error are really fifteen bits 
apart, they may be uncorrectable. This situation can only occur 
when testing because a 2-bit adjacent error refers to two adjacent 
bits on the media. 
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8.15.1 Simulating an ECC Error (continued) 


Before Simulated Error 


Memory Data: 45 67 


Serial Disk Data: 5 4 7 6 
1010 0010 1110 0110 


Simulated Error 
Memory Data: 44 E/ 
Serial Disk Data: 4 4 7 E 


0010 0010 1110 0111 


Table 8-6. Simulated 2-Bit Error Crossing Byte Boundaries 


8.16 RELEASE ON REQUEST 


When ROR is enabled, the 752 tests the VMEbus between each throttle 
for other pending bus requests. If another request is pending, the 
752 releases the bus. It there are no bus requests, the 752 
remains bus master. The throttle value determines how often the 
752 tests the bus: higher throttle values cause the 752 to test 
the bus less frequently; lower throttle values slow down the DMA, 
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SECTION 9: ‘THEORY OF OPERATION 


9.0 GENERAL 


This section is an overview of how the controller works. It deals 
with the functional blocks of the hardware and microcode, and how 
the code affects 752 operation. 


9.1 The Hardware 


The 752 accommodates up to two SMD-E disk drives to VMEbus systems 
using these logic blocks: 


VMEbus Interface 

Register Read/Write and Interrupt (REGCEL) 
Microcontroller 

Direct Memory Access Controller (VMEDMA). 
Disk Data Buffer (FIFO) 

Disk Front End (DSKCEL) 

SMD-E Interface 


9.1.1 VMEbus Interface 


This block contains interface logic for the signals on the VMEbus. 
The 752 is a VME slave for programming purposes, i.e., the register 
file. The 752 is also a slave when it responds to an interrupt 
acknowledge with the interrupt vector. The REGCEL performs both of 
these functions. The address modifier transceiver is used by the 
REGCEL (receive mode) and VMEDMA (driving mode). ‘The 752 is a VME 
master for DMA purposes; it uses DMA to read and update IOPBs and 
also to read and write disk data from host memory. The VMEDMA chip 
performs this function. ‘The VME data bus is 8-, 16-, or 32-bits 
wide; the VME address bus is 32-bits wide. 


NOTE 


The 752 uses only 16 address bits for decoding its 
register addresses (it only compares 12 bits). It drives 
all 32 address bits as a master. ‘The VMEDMA updates the 
lower 16 address bits while the microcontroller updates 
the upper 16 address bits. 


9.1.2 Register Read/Write and Interrupt 
The REGCEL provides the program interface for the 752. The 752 


uses registers to point to an IOPB to be executed, to point toa 
completed IOPB, and to perform various control functions. 
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9.1.2 


9.1.3 


Register Read/Write and Interrupt (continued) 


The VMEbus accesses the registers via a bus that is shared between 
the REGCEL and VMEDMA. ‘There is no contention because the VMEDMA 
cannot acquire the bus while a slave (register) access is in 
progress. The REGCEL answers a register access by the VMEbus with 
the signal DTACK. The upper address bits are decoded and the 
proper address modifier is required to do a register access. 


The microcontroller (micro) accesses the registers via the internal 
data bus. It programs the REGCEL to interrupt it if certain bits 
are set in the CSR or if a timer overflows. Other conditions are 
programmed to assert another interrupt to the micro. 


The REGCEL also supports the VMEbus interrupt protocol. It is 
programmed by the micro to assert the request line to start an 
interrupt sequence. When the system responds with IACK and DSO the 
REGCEL drives the interrupt vector onto the bus and asserts DIACK. 
This process causes the system to execute an interrupt routine. 
The interrupt service routine should clear RIO in the CSR. In this 
way, the 752 passes the completed IOPB back to the systen. 


The REGCEL has a register for storing the address modifier that the 
VMEDMA enables onto the bus. Like the VME address, the address 
modifier is pipelined. A new modifier can be loaded into the 
REGCEL while a different modifier is being driven onto the VMEbus. 


The REGCEL also has two timers. Timer 0 is a watchdog timer: it 
expires and interrupts the microcontroller if it is not 
periodically reset by the firmware. Timer 1 is a counter for 
header errors. A clock comes from the DSKCEL and is asserted when 
a disk header does not match the expected header. If Timer l 
overflows before the desired header is found, a Header Not Found 
error results. 


The Microcontroller 


The 752 uses a 16-MHz 98031 microcontroller. It fetches 
instructions by asserting an address on Port 0, latching the 
address with ALE-L, and reading the data from the EPROM; it reads 
data into Port 0. Many of the instructions cause the micro to 
access an external byte using strobe decoders and a transceiver. 
Many of these external bytes are in the Xylogics LSI chips: 
REGCEL, VMEDMA, and DSKCEL. External bytes are accessed through 
Port 0. Port 1 is used for DSKCEL related outputs. Port 2 is used 
for the upper byte of the EPROM address. 


Port 3 is used for miscellaneous control signals. Inputs can all 
be considered micro interrupts, although most are actually polled. 
Two inputs are from the REGCEL, one from the VMEDMA, and two from 
the DSKCEL. 
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9.1.3 


9.1.4 
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The Microcontroller (continued) 


This block also includes the internal RAM (IRAM) logic. The micro 
really uses the IRAM as a scratch pad RAM; it stores the 
controller, drive, and format parameters there as well as IOPBs. 


The IRAM is Single ported, but is used by both the VMEDMA and the 
micro. Since the microcontroller starts the VMEDMA, it knows when 
the IRAM is off limits for micro access. IOPBs are always DMAed in 
full words for better performance. 


Direct Memory Access Controller 


The VMEDMA controls the transfer of data between the disk buffer or 
IRAM, and the VMEbus. ‘The micro programs the VMEDMA to transfer a 
certain amount of data to/from a specified area in system memory. 
To properly handle odd starting addresses, the amount of data is 
always a sector's worth or less. In this way, the DSKCEL can be 
instructed to do an even or odd address transfer on a per sector 
basis. Before the VMEDMA can transfer data, it must acquire the 
bus by sending out BUSREQ (which must be jumpered to one of the Bus 
Request lines). The system arbiter sends back BGIN via another 
jumper. The VMEDMA then asserts BUSY on the VMEbus and enables the 
752 to control the VME address, data, and control lines. 


A transfer involves asserting a valid address, asserting DSO and/or 
DS1 and valid write data or read data, waiting for DTACK, and 
proper buffer control. The order of the buffer request and data 
strobe is reversed, depending on the direction of the transfer. 


The DMA circuitry pipelines data to increase performance. The 
pipeline allows one word of data to be transferred on the bus while 
another is transferred to the buffer. In this way, the access 
times of the buffer and the bus can be overlapped (except for the 
first and last transfers of a burst). A prefetch primes the 
pipeline, and at the end of the burst the pipeline is emptied. 


The disk buffer is word wide and uses a longword wide pipeline. The 
interface logic turns a VMEDMA longword request into two buffer 
(word) requests. The IRAM is byte wide and uses a word wide 
pipeline. The interface logic turns the VMEDMA word request into 
two IRAM requests. 
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9.1.5 


9.1.6 


9.1.7 


Disk Data Buffer 


The 8K-byte buffer is organized word wide. Disk data has byte 
parity and the parity bits are stored in a RAM. The DSKCEL will 
not start a write unless a sector's worth of data is in the buffer. 
The DSKCEL will not start a read unless the buffer has roam for a 
sector's worth of data. The micro tracks buffer use and starts/ 
stops the VMEDMA and DSKCEL as necessary. 


Disk Front End 


The DSKCEL is a downloadable disk sequencer. The micro loads the 
disk read, write, and format programs into the DSKCEL on power up, 
and modifies the programs when new format parameters are loaded or 
an alternate command (such as Read Header, Data, ECC) is received. 
The DSKCEL issues sane SMD control signals, such as Read Gate and 
Write Gate, while the micro issues others, such as Cylinder Tag and 
Unit Tag. Generally, if timing is critical, the DSKCEL issues the 
Signal since it runs off the disk bit clock. The DSKCEL has serial 
registers for FIFO data, the Header, and ECC. It performs sync bit 
search, header check, and ECC check and provides status bits to the 
micro. The DSKCEL interrupts the micro when done. DSKCEL Done may 
mean Header Found, End of Sector, or Bad Spot Found. Generally, 
the DSKCEL runs on aeé sector-by-sector basis, with the micro 
controlling how many sectors are transferred. The micro allows the 
DSKCEL to run. The program starts running when a sector or index 
pulse comes in from the disk. The micro informs the DSKCEL when 
the next sector involves an odd address DMA and when the current 
sector is the last. ‘The DSKCEL also performs other functions, such 
as ECC correction, runt sector detection, and mid-transfer head 
tags. 


SMD-E Interface 


This block contains interface logic for SMD Connectors. ‘The micro 
controls the tags for Unit Select, Cylinder, Head, Control 
(read/write) and the Unit Select lines. Various disk status lines, 
and the sector and index pulses are received and used by either the 
micro or the disk sequencer. The micro controls whether the pulses 
to the DSKCEL include sector pulses or just the index pulse. 
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9.1.7 


9.1.8 


9.1.9 


9.1.10 


9.2 
9.2.1 
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SMD-E Interface (continued) 


The SMD interface chips require -5 volts from an on-board regulator 
in order to operate properly. A drive configured as any Unit 
Number, from 0 thru 7, can be used with any port. 


NOTE 


When no disk unit is selected, servo clock is a free- 
running 10-MHz clock. This is typically used during ECC 
correction. ‘The clock synchronizer ensures that no clock 
slivers get into the DSKCEL when the Read Gate is 
Switched. The disk sequencer clock is servo clock 
(interface clock) when writing the disk and read clock 
when reading the disk. The write clock is simply delayed 
servo clock. 


Power=-up 


During power-up, the Open Cable Detect signal is asserted on the 
drive interface. This signal disables any erroneous writes. The 
bus signal SYSRESET sets the error LED (L2) and asserts SYSFAIL on 
the bus. The micro runs its diagnostics and then clears L2 and 
SYSFAIL. 


Power-down 


During power-down, the 752 responds to ACFAIL by turning off the 
DSKCEL (it allows any writes to finish the current sector) and then 
asserting Open Cable Detect to the drive. This sequence generates 
a fatal error which cannot be reset until ACFAIL is deasserted. 


System Reset 


When the 752 detects SYSRESET, it resets its internal micro and the 
three custan integrated circuits. This sequence immediately 
terminates any writes to the disk (possibly leaving it with an 
unreadable sector). The 752 then executes the power-up 
diagnostics. 


THE MICROCODE 

The Kernel 

Figure 9-l] illustrates the kernel. It is entered after the 
Power-up test and initialization. It has four major functions, of 


which three will be discussed. The fourth function is scheduling 
DMA, and would needlessly complicate this discussion. 
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is AIO Set? 


Each time around the kernel, the 752 tests to see if the host set 
AIO. If AIO is set, the 752 must process the AIO. This processing 
entails reading the IOPB and placing it in its internal command 
queue. If the queue is full, the 752 saves the address of the IOPB 
so that it can later read it into the queue. The queue can 
accommodate 14 IOPBs, plus a priority IOPB; the 752 saves the next 
32 IOPB (chain) addresses. This function is really tested several 
times in the kernel, but for simplicity Figure 9-1 shows it as a 


Single function. 


Power-up test 


Is 
any !OPB 
ready for 
compl. 


Complete Function 
Update IOPB 
Interrupt 


Figure 9-1. The Microcode Kernel 
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9.2.3 


9.2.4 


9.2.5 


9.3 


9.3.1 


Is Start Queue Empty? 


The IOPBs in the internal queue are divided into three groups: 
seek not started queue, seek started, and seek complete or not 
required. When first entering the queue, the IOPBs belong to the 
first group, seek not started queue. This step examines the IOPBs 
to determine if a seek is required. If a seek is required, and the 
drive is not busy, the 752 issues the Seek command to the drive and 
assigns the IOPB to the second queue, seek started. If a seek is 
not required, the 752 marks the IOPB as having its seek complete 
and assigns it to the third group, seek done or not required. 


is Any IOPB Ready for Completion? 


The 752 checks for an IOPB in the third group, seek complete or not 
required. It does this by first checking if an IOPB has a seek 
done set; if not, it selects each drive in the second group, seek 
started, to determine if a seek is complete. The 752 executes the 
first seek done IOPB. When the 752 completes the function, it 
updates the IOPB and issues an interrupt. 


Queuing IOPBs for Execution 


The 752 command queue accommodates 14 IOPBs. The first AIOs have 
their respective IOPBs (IOPB chains) read directly into the queue 
until it is full. If COP is set, the 752 reorders the IOPBs inside 
the queue, so that it executes them in proper order. 


As the 752 completes an IOPB, it frees up a slot in the internal 
queue, and reads in a new IOPB. If COP is set, the 752 inserts the 
new IOPB at the proper point in the reordered IOPBs. 


PERFORMING A FUNCTION 
The 752 performs each function differently. If a function requires 
a seek, the 752 issues the seek and waits for it to complete before 


performing the function. The following subsections group similar 
functions together and explains their differences. 


NOP 


The NOP command verifies the 752 is operational: it reads the IOPB 
from host memory, sets DONE, and posts a completion code. 
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9.3.2 Normal Reads and Writes 


Normal reads and writes are very Similar commands regarding 752 
processing. The main difference between reads and writes is which 
way, and when, the data moves. On writes, the 752 DMAs the data 
and begins the disk transfer when the FIFO holds one sector's worth 
of data. On reads, the 752 begins the disk transfer immediately 
and begins the DMA as soon as the first word is available from the 
FIFO. 


When enabled, the disk sequencer compares every header that arrives 
under the heads with the target sector. When a header compare is 
successful, the 752 also tests the header verify. If both tests 
are successful, the transfer occurs on that sector. To continue 
the transfer, the 752 loads the next target header so it can doa 
comparison on the next sector that arrives under the heads. ‘the 
752 does not wait for index before comparing headers. | 


If more than one sector is specified, the 752 increments the disk 
address on successive sectors. First, the controller increments 
the sector number until it reaches the maximum sector address. 
When the 752 reaches the maximum sector address, it clears the 
sector address and increments the head address. When the 752 
reaches the maximum head and sector addresses, it clears them and 
increments the cylinder address. When the 752 reaches the maximum 
sector, head, and cylinder addresses, the next sector causes an 
Illegal Cylinder Address error. 


The 752 continues, and completes the IOPB as soon as it completes 
the DMA and disk transfers, or an uncorrectable error occurs. 


9.3.3 Seeks 


Depending on the subfunction, the 752 may select the drive and read 
the first header that arrives under the heads. If it is a spare or 
bad header, the 752 reads the next header until it gets a good one. 
The 752 returns the data read in the header in the IOPB. 


9.3.4 Drive Reset 


This command issues a Fault Clear and then a Recalibrate (Return To 
Zero) command to the drive. The 752 waits for the Recalibrate to 
complete before completing the IOPB. The wait for recalibrate done 
is a background task, and the contoller continues processing other 
IOPBs (not on the drive being recalibrated). 
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9.3.5 


9.3.6 


9.3.6.1 


9.3.6.2 


9.3 6.3 


9.3.6.4 


9.3.7 
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Write and Read Parameters 


Section 7 describes these functions in detail. 


Extended Read and Write Commands 


This section is similar to Section 9.3.2; the following subsections 
detail their differences. 


Track Headers Commands 


The disk sequencer waits for index before determining where to 
Start the transfer. Track headers commands always start at index. 
The number of sector headers returned equals the physical sector 
count (read with a Read Drive Parameters command). 


Header, Header Verify, Data, and Data ECC 


The disk sequencer waits for index before determining where to 
Start the transfer. Header, Header Verify, Data, and Data ECC 
commands use the sector address as an offset count from index when 
determining where to start. The 752 increments the sector address 
during a multisector transfer, but does not clear it if it reaches 
max sector. The controller inhibits the Illegal Sector Address 
error and does not increment the head and cylinder addresses. 


Defect Map Extended 

The disk sequencer waits for index, syncs up to the manufacturer's 
Defect Map and reads it into memory. ‘The 752 only executes one 
track per IOPB. 

Read Verify 

The disk sequencer executes a Read command, and the DMA sequencer 
performs as if it is doing a disk write. The 752 compares the 
serial data from the FIFO/SERDES with the data from the disk. A 


miscompare causes a verify failure. The 752 returns the failing 
disk address in the IOPB. 


Di bj 
The 752 executes the power-up self test. 
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9.3.8 


9.3.9 


9.4 


Read Ahead Theory of Operation 


The 752, uSing an 8K-byte FIFO, reads data into the buffer before 
the UNIX device driver actually requests it. After completing any 
normal Read command, the 752 continues reading disk data into its 
buffer until the buffer fills (fifteen 5l2-byte sectors) or 
software requires a cylinder seek. If the next request to the 752 
is a read for the next logically contiguous sector of data, it 
transfers the data from its buffer to system memory and completes 
the I/O request. The 752 terminates read ahead when it reaches a 
buffer full condition, or when software requires a cylinder seek. 
The controller satisfies subsequent reads from its buffer until it 
exhausts all read ahead data. It completes the next Read command 
with a standard disk read, and refills the read ahead buffer. 


The 752 refills any buffer space freed by a Read command while the 
read ahead is in process before terminating read ahead. Thus, the 
752 can transfer an entire cylinder's worth of data at disk speed 
even though the UNIX I/O requests may not be sent at disk speed. 
Any request other than a logically contiguous read causes the 752 
to flush the buffer and execute the specific command. 


Dyna-throttle Theory of Operation 


During a Read command, each time firmware executes the DMA 
scheduler, the 752 calculates the amount of data currently in the 
buffer and DMAs from one to seven sectors to system memory. This 
method proves extremely efficient when transferring data previously 
brought in from the disk via read ahead; it also enables the 752 to 
catch up from heavy bus load periods when the DMA falls behind. 
Dyna-throttle does not override the normal throttle and throttle 
dead time features that tune system bus activity. 


COMPLETING A FUNCTION 


The 752 completes the transfer when both the DMA and disk transfers 
are complete. The 752 updates the IOPB in host memory, interrupts, 
and clears BUSY if all IOPBs in its queue are complete. 


If an error occurs, the 752 completes the errored IOPB and 
continues processing the other IOPBs. 


If a fatal error occurs, the 752 finishes the IOPB(s) in process, 
posts the fatal error code, and sets FERR. ‘The host must execute a 
Controller Reset before sending any IOPBs to the 752. 
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SECTION 10: DRIVE INTERFACE 
10.0 GENERAL 
This section provides useful information for installing and 


maintaining your Xylogics Model 752 disk controller. 


10.1 VMEbus INTERFACE SIGNALS 


Used By 
Mnemonic Conn. Pin 132 Description 
AOl PIA 30 Y 
A02 PlA 29 Y 
A03 PIA 28 Y 
A04 P1lA 27 Y 
AO5 P1A 26 Y 
A06 PIA 25 Y 
AO7 PIA 24 Y 
A08 P1C 30 Y 
AO9 P1C 29 Y 
Al10 P1C 28 Y 
All P1C 27 Y 
Al2 P1C 26 Y 
Al3 P1C 25 Y 
Al4 PLC 24 Y 
AlL5 P1C 23 A Address Bus 
Al6 P1C 22 Y 
Al7 P1C 21 Y 
Als P1C 20 Y 
Al9 P1C 19 Y 
A20 P1C 18 Y 
A21 P1C 17 Y 
A22 P1C 16 Y 
A23 P1C 15 Y 
A24 P2B 4 Y 
A25 P2B 5 Y 
A26 P2B 6 Y 
A27 P2B 7 Y 
A28 P2B 8 Y 
A29 P2B 9 Y 
A30 P2B 10 Y 
A31 P2B 11 Y 
AMO PIB 16 Y 
AM P1B 17 Y 
AM2 P1B 18 Y Address Modifier 
AM3 P1B 19 Y 
AM4 PIA 23 y 
AM5 PLC 14 Y 
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10.1 VMEbus INTERFACE SIGNALS (continued) 


Used By 
DOO PIA 1 Y 
DO1 PIA 2 Y 
DO2 PIA 3 Y 
D03 PIA 4 Y 
DO04 PIA 5 Y 
DO5 PIA 6 Y 
D06 PIA 7 Y 
DO7 PLA 8 Y 
DO8 = 1Ke 1 Y 
DO9 PIC 2 Y 
DLO PIC 3 Y 
D1l PIC 4 Y 
D12 PIC 5 Y 
D13 PIC 6 Y 
D14 P1C 7 Y 
D15 PIC 8 Y Data Bus 
D16 P2B 14 Y 
D17 P2B 15 Y 
D18 P2B 16 Y 
D19 P2B 17 Y 
D20 P2B 18 Y 
D21 P2B 19 Y 
D22 P2B 20 Y 
D23 P2B 21 Y 
D24 P2B 23 Y 
D25 P2B 24 Y 
D26 P2B 25 Y 
D27 P2B 26 Y 
D28 P2B 27 Y 
D29 P2B 28 Y 
D30 P2B 29 Y 
D31 P2B 30 Y 
Strobes 
aAs* PIA 18 Y Address Strobe 
pso* PIA 13 Y Data Strobe Zero 
ps1* P1LA 12 Y Data Strobe One 
DTACK* PIA 16 Y Data Transfer Acknowledge 
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10.1 VMEbus INTERFACE SIGNALS (continued) 


Mnemonic §§ Conn. Pin 
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PIB 
PIA 


PLB 
P1B 
P1C 


P1B 
P1B 
PIB 
PIB 


P1B 
PIB 
PIB 
PIB 


P1B 
PIB 
PIB 
PIB 


PIB 
P1B 
P1B 
P1B 
PIB 
PIB 
PIB 


PIA 
PIA 
PIA 


21 
10 


on un Mm CO OV > RIN Ee 
co) - 


~~ 
_ 


bt ht be 
Om Wh 


Used By 
132 


131 


aa 


KMRKKK KRKKK KKK K ORS K 


KKK KKK KKK K 


, tj 


Serial Clock 
System Clock 


Bus Busy 
Bus Clear 
Bus Error 


Bus Grant In 


Bus Grant Out 


Bus Request 


Interrupt Request Levels 


Interrupt Acknowledge 
Interrupt Acknowledge In 
Interrupt Acknowledge Out 
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10.1 


10.2 


VMEbus INTERFACE SIGNALS (continued) 


Used By 
Mnemonic Conn. Pin 152 
Miscellaneous 
ACFAIL* P1B 3 Y 
LWORD* PIC 13 Y 
RESERVED P2B 3 N 
SERDAT* P1B 22 N 
SYSRESET* PIC 12 Y 
WRITE* PIA 14 Y 
Power 
+5V PIA,B,C 32 Y 
+5V P2B 1,13 ,32 Y 
+5V STDBY PIB 31 N 
+12V PIC 31 N 
-12V PIA 31 N 
GND PIA 9,11,15,17,19 Y 
GND PIB 20,23 Y 
GND P2B ~=§=2,12,22,31 Y 
GND PIC 9 Y 
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, ‘pti 


AC Failure 
Longword 
Reserved 
Serial Data 
System Reset 
Write 


+5 VDC 

+5 VDC 

+5 VDC Standby 
+12 VDC 

-12 VDC 

Signal Ground 
Signal Ground 
Signal Ground 
Signal Ground 


Several different pin-numbering systems define the SMD-E interface. 
This section lists both CDC's method, and the industry standard 
(SIND) . (Physically, the cables are ribbon cables with crimp 


connectors on each end.) 


NOTE 


Xylogics follows the industry standard for pin-numbering. 
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10.2 
Name Cable Pint/- 
Cpe 
Unit Select 
Unit Select Tag A 52/22 
Unit Sel. Bit 0 A 53/23 
Unit Sel. Bit l A 54/24 
Unit Sel. Bit 2 A 56/26 
Unit Sel. Bit 3 A 57/27 
Open Cable Det. A 44/14 
Unit Selected B 09/22 
Unit Ready A 49/19 
Control 
Tag 1 A 31/01 
Tag 2 A 32/02 
Tag 3 A 33/03 
Pwr. Seq. Hold A 59 


Sequence Pick In 
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29 


Pint/- 
SIND 


44/43 


46/45 
48/47 
52/51 
54/53 


28/27 


17/18 


38/37 


02/01 


04/03 


06/05 


58 


57 


» £33 


EXTENDED STORAGE MODULE DRIVE INTERFACE (continued) 


, tj 


Initiates a unit’ select 
sequence along with the Unit 
Select bits. 


These binary weighted 
Signals determine which 
drive (out of sixteen) the 
752 selects. 


The 752 uses this signal to 
deselect the drive in the 
event of power failure. 
A "B" cable signal; the 
drive has been selected. 


The selected drive is up to 
speed; the heads are loaded, 
and not faulted. 


Cylinder Select Tag; the 
drive seeks to the cylinder 
selected by Bus bits 0-10. 


Head Select Tag; the drive 
selects the head specified 
by Bus bits 0-9. 

Control Tag; the drive 
executes the function 
defined by Bus bits 0-9. 


Used for power-sSequencing 
with Remote/Local; always 
enabled on the 752. 


Used for power-sequencing 
with Remote/Local; always 
enabled on the 752. 
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Name 


Bus 


Bus 


Bus 


Bus 


Bus 


Bus 


Bus 


Bus 


Bus 


Bus Bit 10 


Clocks and Data 


Bit 0 


Bit 1 


Bit 2 


Bit 3 


Bit 4 


Bit 5 


Bit 6 


Bit 7 


Bit 8 


Bit 9 


Index 


Read Clock 
Read Data 
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Cable 


A 


w 


Pint/- 
Coe 


34/04 


35/05 


36/06 


37/07 


38/08 


39/09 


40/10 


41/11 


42/12 


43/13 


60/30 


48/18 
17/05 
16/03 


134 


Pint/- 
SIND 


08/07 


10/09 


12/11 


14/13 


16/15 


18/17 


20/19 


22/21 


24/23 


26/25 


60/59 


36/35 
08/09 
06/05 


EXTENDED STORAGE MODULE DRIVE INTERFACE (continued) 


c ‘pti 
Write Gate Enable or bit 0 
of head or cylinder. 


Read Gate Enable or bit 1 of 
head or cylinder. 


Servo Offset (+) or bit 2 of 
head or cylinder. 


Servo Offset (-) or bit 3 of 
head or cylinder. 


Fault Clear or bit 4 of head 
or cylinder. 


Address Mark Enable or bit 5 
of head or cylinder. 


Recalibrate or bit 6 of head 
or cylinder. 


Data Strobe Early or bit 7 
of head or cylinder. 


Data Strobe Late or bit 8 of 
head or cylinder. 


Release or bit 9 of head or 
cylinder. 


Bit 10 of cylinder address. 


Pulses for every index mark. 
Synchronizes read data. 
Reads data from drive. 
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EXTENDED STORAGE MODULE DRIVE INTERFACE (continued) 


Name 


Cable 


Pint/- 
CoC 


Clocks and Data (continued) 


Sector 


Servo Clock 


Write Clock 


Write Data 


Status 
Address Mark 


Busy 


Fault 
On-cylinder 


Seek End 


Seek Error 


Write—protect 
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A 


55/25 


14/02 
19/06 


20/08 


50/20 


51/21 


45/15 
47/17 
23/10 


46/16 
58/28 


135 


Pint/- 
SIND 


50/49 


02/03 
12/11 


14/15 


39/40 


42/41 


30/29 
34/33 
20/19 


32/31 
56/55 


, tj 


Pulses for every sector 
(except during index). 


Synchronizes write data. 


Clock sent to drive with 
synchronized write data. 


Write data sent to drive. 


The drive 
sector mark. 


encountered a 


One port is busy in a dual 
port drive. 


The drive is faulted. 


The drive is on-cylinder. 


The drive completed a seek, 
or loaded the heads. 


The drive has a seek error. 


The drive is 
write—-protected. 


53 Third Avenue 


Burlington, MA 01803 


